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머리말 


위대한 령도자 김정일원수님께서는 다음과 같이 지적하시였다. 

《프로그람을 개발하는데서 기본은 우리 식의 프로그람을 개발하는것입니다. 우리는 
우리 식의 프로그람을 개발하는 방향으로 나가야 합니다.》 

프로그람기술을 빨리 발전시키는것은 나라의 정보기술을 높은 수준에 올려세우기 
위한 중요한 요구의 하나이다. 

위대한 령도자 김정일원수님의 현명한 령도에 의하여 오늘 우리 나라에는 정보기 
술을 빨리 발전시 킬수 있는 물질기 술적 토대 가 튼튼히 마련되 였으며 새 로운 정 보기 술성 
과들이 련이어 이룩되고있다. 

나라의 정보기술을 높은 수준에 올려세우는데서 중요한것은 우리 식 조작체계 
《붉은별》에서 응용할수 있는 프로그람들을 빨리 발전시키는것 이다. 

5학년《를퓨터》에서 는 대 표적 인 프로그람작성언어 인 C 를 리용하여 프로그람작성 
의 기초적 인 방법들을 배운다. 

프로그람을 작성 한다는것 은 물려 는 문제 를 잘 파악해 서 그 물이 순서 와 방법 을 결 
정한 다음 그것 을 를퓨터 가 아는 프로그람언어 로 서 술해 주는것 을 말한다. 

먼저 프로그람작성에서 기초로 되는 알고리듬과 프로그람언어에 대한 기본지식들 
에 대하여 배운다. 그리고 간단한 프로그람작성과정을 통하여 C 언어의 기본구성요소 
들 에 대 하 여 배우게 된 다. 

모든것은 기초가 든든해야 훌륭한 결실을 볼수 있다. 

우리는 이 과목학습을 실속있게 하여 앞으로 보다 능률적인 우리 식의 응용프로그 
람들을 개발할수 있는 기초를 튼튼히 다짐으로써 우리 학생들이 사회주의강성대국의 
밝은 앞날을 떠메고나갈 훌륭한 과학기술인재로 자라나도록 크나큰 사랑과 은정을 베 
풀어주고계 시는 위대한 령도자 김정 일원수님의 믿음과 기대 에 높은 실력 으로 보답하 
여 야 한다. 
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제 1 장. 모르그#작성의 기초지져 

콤퓨터의 동작원리를 다 파악하려면 를퓨터장치의 요소요소가 다 어떻게 맞물려 
동작하는가를 잘 알아야 할것이다. 이에 못지 않게 프로그람작성원리를 잘 알아야 콤 
퓨터의 동작원리를 잘 파악할수 있으며 콤퓨터를 더 잘 다룰수 있다. 

제1점. 곧퓨터 J 는 문제봄 붙려면 

1. 문제풀이단계 

례를 들어 어떤 수학문제를 푼다고 할 때 먼저 그 문제를 여러번 읽으면서 문제의 
요구를 정 확히 파악한데 기 초하여 물이 방법 을 찾아내 야 한다. 그다음 찾아낸 물이 방법 
대 로 종이 우에 차례 차례 물어 서 주어 진 문제 의 답을 얻 는다. 즉 문제 물이 파정 은 다음 
과 같다. 

문제파악 l —» l 풀이방법연구 I 다 ^이 (계산) I 나 

이 문제를 를뉴터로 물려고 하는 경우에는 다음과 같은 과정을 거쳐야 한다. 

(두목)— 문제파악 빠 알고리듬작성 _ 프로그람작성 빠 프로그람실행 1 빠^^ 

를뉴터 에 의 한 문제 물이 파정 을 단계 별 로 보기 로 하자. 

1) ^제악 

이 단계에서는 문제의 요구를 정확히 파악하여 문제풀이에 필요한 조건으로 되는 
입력자료 (또는 초기자료)와 구하려는 출력자료 (결과자료)를 찾는다. 

풀이를 위한 수학적인 정식화(수학적모형화)를 진행한다. 

려 I 1: 두 밑변파 높이 에 의 하여 제형의 면적 을 계산하는 문제를 보기 로 하자. 

입 력 자료 : 두 밑 변 a , b 
높이 h 

출력자료: 제형의 면적 S 

수학적모형화: S=—(a + b)h 

수학적 모형 화가 이 루어 지 면 수값풀이 를 진행 하여 야 한다. 

례 2： 2차방정식 ax 2 + bx + c = 0의 실수풀이를 구하자. 

입 력 자료: 2차방정 식 의 결수 a , b , c 
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줄력 자료: 실수물이 X 

수학적 모형 화 : 판별 식 d = b 2 - 4 ac 의 값에 따라 

d > 0인 경우 XX , 2 = 一느土、’표 

2 a 

d = 0인경우 x = — 

2 a 

d < 0인 경우 풀이가 없다. 

수학적모형화의 매 경 우에 따르는 수값풀이 를 진행한다. 

2) 알고리듬작성 

알고리듬이 란 주어 진 문제를 풀기 위한 과정 즉 어떤 연산들을 어떤 순서로 집행하 
겠는가를 밝혀놓은것을 말한다. 

문제파악이 끝나면 풀어야 할 처리내용을 자기가 알수 있게 순서대로 적어놓아야 
한다. 즉 알고리 듬을 작성하여 야 한다. 

앞의 례들을 다음과 같이 순서 화할수 있다. 

Ell 1： ① 변 a , b 와 높이 h 를 입 력한다. 

② 제형의 면적 S = i(a + b ) h 를 구한다. 
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③ S 를 출력한다. 

례 2： ① 2차방정 식 의 결 수 a , b , c 를 입 력한다. 

② 판별식 d = b 2 - 4 ac 를 구한다. 

③ 선에 따라 물이를 구한다. 

④ 물 이를 줄력 한다. 

알고리 듬작성 과정 은 콤퓨터 에 의한 문제 풀이단계 에 서 가장 기 본적 인 부분을 이 루 
며 어렵고 창조적인 사고활동을 요구하는 작업 파정이다. 구체적인 알고리듬에 대하여 
서는 뒤에서 보기로 한다. 

3) 프로그람작성 

알고리 듬을 콤퓨터 가 리해할수 있는 언어 로 바꾸어놓는 과정 을 프로그람작성 이라 
고 한다. 앞의 제 형면적 계 산례 를 C 언어프로그람으로 작성하면 다음과 같다. 

^include < stdio . h > 
mainO 
{ 

int a , b ； // 옹근수형변수 a , b 선언 

int h ； // 옹근수형변수 h 선언 

float S ； // 실수형변수 S 선언 

scanf (‘‘% d % d % d ”, & a , & b , & h ) ； // 자료입 력 

S = — *( a + b )* h ； // 면적계산 
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printf df \ n ”, S ) ； // 면적 출력 
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4) 프로그람검열 

프로그람검 열 은 앞단계 들의 검 토과정이 다. 

매 단계 에 서 여 러 가지 잘못 즉 오유가 있 을수 있다. 오유에는 두가지 가 있다. 하 
나는 프로그람언어 의 문법 적오유이 며 다른 하나는 잘못된 사고로 인한 론리 적오유이다. 
문제 파악단계 와 알고리 듬작성단계 에서 는 론리 적오유가 발생 될수 있으며 프로그람작성 
단계 에서 는 문법 적오유가 나올수 있다. 

그러므로 새 로 작성한 프로그람을 실행 하기 전에 검 열단계를 거처 야 한다. 

검열과정에 모든 오유들이 발견되고 수정되여야 한다. 

5) 프로그람실행 

프로그람개 발환경 을 마련하고 앞에서 작성한 프로그람을 건반을 통해 편집한 다음 
각종 지령을 주어 실행시켜야 한다. 

실행 에서 오유가 나오면 수정하여 다시 실행시 킨다. 오유가 없는 경 우에 는 답을 
얻게 된다. 

2. 알고리등작성 


1) 알고리듬의 분류 

문제 를 빠른 시 간에 정 확하게 물자면 그 문제 를 물기 위 한 단계 를 옳바로 결정 하 
여 야 한다. 

콤퓨터로 풀어야 할 문제가 제기되면 콤퓨터가 풀어야 할 문제풀이순서인 알고리 
듬을 작성한 다음 이것을 콤퓨터 가 알수 있는 언어 로 바꾸어 콤퓨터 에 입 력시 키면 콤 
뉴터 는 그것 에 의 하여 동작을 수행 하게 된 다. 

같은 문제라도 그것을 어떻게 구성하는가에 따라 서로 다른 알고리듬이 될수 있다. 
례로 두 수의 최대공통약수를 구하는 알고리듬에는 두 수가 공통으로 가지는 약수들가 
운데서 제 일 큰것을 찾는 방법과 유클리드련제법을 리용하여 구하는 방법 이 있다. 

어느 방법을 선택하는가에 따라 연산순서 즉 알고리듬이 달라전다. 

이 와 같이 여 러 가지 방법가운데서 어 느것 을 선택하겠는가 하는것 은 콤퓨터 의 리 용 
측면을 놓고 결정하여야 한다. 좋은 알고리듬이라고 할 때는 연산조작회수가 적고 프 
로그람의 크기가 작은것 이다. 

- 직선형(순자형)구조 

다음과 같이 두 밑변과 높이가 주어졌을 때 제형의 면적을 구하는 알고리듬을 보 
기로 하자. 

① 시작 

② 변수 a , b 에 두 밑 변의 길 이값을，변수 h 에 높이값을 넣는다. 

③ 변수 예 i(a + b ) h 를 넣는다. 
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④ 변수 s 에 있는 결 과값을 화면 에 표시한다. 

⑤ 끝 

여 기서 변수는 수학문제 를 풀 때의 변수가 아니 라 프로그람에서의 변수 즉 콤퓨터 
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의 기억장소를 의미한다. 그러므로 이제부터 우리가 알고리듬에서 쓰게 되는 모든 변 
수는 기억장소라고 생각하고 콤퓨터에서 진행되는 과정을 생각하면서 콤퓨터에 지령을 
주듯이 알고리듬을 작성해주어야 한다. 

시 작을 하면 콤퓨터는 새로운 과제를 수행 할 준비 단계 에 들어 간다. 

콤퓨터가 두 밑변의 길이와 높이값을 알아야 면적을 계산하므로 콤퓨터에 이 3개 
의 값을 넣어 주어 야 하는데 콤퓨터 는 모든 자료를 기 억 기 에 기 억하므로 기 억 장소 a , b 
에는 두 밑변의 길이값을， h 에는 높이값을 넣어주어야 한다. 

기 억 장소 s 에 는 면적 값을 계 산하여 넣 어 주고 이 것 이 화면 에 표시 되 여 야 사용자가 
알게 되 므로 기 억장소 s 에 있는 면적값을 화면에 출력해 야 한다. 

처음에 주어지는 값들을 변수 a , b , h 에 넣어주는것을 입력 이라고 하며 계산한 값 
을 변수 s 에 넣 어 주는것 을 값주기 라고 하고 기 호 는로 표시 한다. 

우의 알고리듬은 처음부터 씌여진 순서대로 처리하게 구성되여있다. 이런 형태의 
알고리 듬구조를 직 선형구조라고 한다. 

- 갈래형구조 

한 학생 의 평 균성 적 을 입 력하여 3. 5이 상이 면 《 합격》，그아래 이면 《 불합격》이 
라고 표시 하는 알고리 듬을 만들자. 

① 시작 

② s (성 적 ) 초기 값입 력 

③ 만일 s ^3.5 이면 ④에로 이행，그렇지 않으면 ⑥에로 이행 

④ 〈〈 합격》출력 

⑤ ⑦에로 이행 

⑥ 〈〈 불합격》출력 

⑦ 끝 

이 알고리듬은 처리가 번호순서로 차례로 진행되는것이 아니라 도중에 조건에 따 
라 두갈래가운데서 어느 한 갈래를 따라 처리하게 되여있다. 즉 입력하는 성적값이 
3. 5이 상이 면 ①，②，③，④，⑤，⑦의 순서 로， 3. 5보다 아래 이면 ①，②，③，⑥， 
⑦의 순서 로 처 리 가 진행 된다. 이 와 같이 조건에 따라 여 러 갈래 가운데 서 어 느 한 갈 
래를 택 하여 처 리를 진행 하는 형 태의 알고리 듬을 갈래형구조라고 한다. 

- 순환형( 반복형 ) 구조 

수렬의 합 s = l + 2 + 3 + 4 + *" + 100 을 계 산하는 알고리 듬을 만들어 보자. 

이것 을 계산하기 위해 1씩 주기적 으로 증가하는 수를 변수 i 에 넣 고 현재의 i 값까 
지의 합을 변수 s 에 넣는것 으로 하고 표를 동하여 그 과정을 보자. 


i 계 산 

i 값 

s 계 산 

s 값 

i 나) 

0 

s ，— 0 

0 

i 니+1 

1 

s — s+i 

1 

i 니+1 

2 

s — s+i 

1+2 

i 니+1 

100 

s — s+i 

1+2+3 + •••+100 
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표에서 보는바와 같이 첫 단계 i <- 0， s <- 0를 제외하고는 i <— i +1 , s <- s + i 라는 계산을 




100 번이 나 반복한다. 

여 기서 iei +1 은 이 미 i 기 억장소에 기 억된 값에 1을 더하여 다시 i 기 억장소에 기 억 
시 킨다는 뜻을 담고있다. 그러 면 i 에 는 1씩 증가된 값이 넣 어질것 이다. 

s 는 s+i 는 이미 얻어진 합 s 에 이제 새로 들어온 i 값을 더하여 다시 변수 s 에 넣으 
므로 s 에는 i 가 변할 때마다 그 값까지의 합이 설정된다. 

그러 므로 iei +1， ses + i 를 100번 반복수행한 다음 결 과를 출력하도록 알고리 듬을 
구성하면 된 다. 몇번 반복수행 하는가는 매 번 호의 값이 얼 마인가를 알아보고 100이 되 
면 반복을 그만하게 하면 된다. 

알고리 듬은 다음과 같다. 

① 시작 

② i 녜 ， s 녜 

③ i =100 이면 ⑦에로 이행，그렇지 않으면 다음처리 (④에로) 

④ i 니+1 

⑤ s 는 s+i 

⑥ ③에로 이행 

⑦ s 값 출력 

⑧ 끝 

우의 알고리 듬에 서 반복처 리 를 하게 하는 ③과 ⑥을 변경하여 다음과 같이 알고리 
듬을 만들수 있다. 

① 시작 

② i 네， s 녜 

③ i 니+1 

④ s 는 s+i 

⑤ i <100 이면 ③에로 이행，그렇지 않으면 다음처리 (⑥에로) 

⑥ s 값 출력 

⑦ 끝 

이 와 같이 알고리 듬구성 은 여 러 가지 로 작성할수 있는데 보다 간단할수록(처 리 회 수 
가 작을수록) 더 좋은 알고리듬으로 된다. 

우의 알고리듬은 어떤 조건을 만족할 때까지 ( i 값이 100이 될 때까지) 처 리를 반 
복(③，④，⑤부분)하게 되 여있다. 이 런 형 태를 순환형구조，반복처 리하는 부분을 순 
환부라고 한다. 

일반적으로 알고리듬은 직선형，갈래형，순환형 또는 그것들의 혼합으로 이루어져 
있다. 

알고리듬은 다음의 조건을 만족시켜 야 한다. 

① 같은 자료에 대 하여 실행하면 같은 결과가 얻 어져야 한다. 

② 처리는 반드시 유한번의 처리로 끝나야 한다. 

③ 하나의 문제 에서만이 아니 라 그와 같은 형 태의 여 러 문제 에서도 모두 적 용할수 
있어 야 한다. 
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작성자에 따라 알고리듬이 달라질수 있다. 


2) 알고리듬의 표시방법 

알고리듬은 사용자가 콤퓨터가 풀어야 할 문제의 처리내용을 쓴것이므로 그것을 
작성하지 않은 사람도 보고 쉽게 프로그람으로 옮길수 있게 알아보기 편리하게 되여야 
한다. 이 로부터 알고리 듬을 표시하는 방법 에 는 글로 서 술하는 방법，그림 으로 표시하 
는 방법 등 여 러 가지 방법 이 있다. 

글로 서 술하는 방법 에 는 문제 풀이순서 를 사람들이 사용하는 일 반언어 로 서 술하는 
방법 (우의 례들)과 프로그람모조코드(의사코드)로 표시하는 방법 이 있다. 

그림 으로 표시하는 방법 에서 는 문제 풀이의 전 과정 을 직 관성 있게 나타내 기 위하여 
흔히 흐름도나 블로크도와 같은 그림 으로 표시한다. 

그러 면 직 관적효과가 강한 흐름도와 블로크도에 대 하여 보기 로 하자. 

- 호름도 

몇개의 기하학적도형과 처리의 방향을 나타내는 화살을 리용하여 풀이의 전 과정을 
나타내 는 알고리 듬을 직 관적 으로 표시한것 을 흐름도라고 한다. 

흐름도는 프로그람작성 에 매 우 편 리하며 직 관성 이 있 으므로 프로그람에 서 나타나 
는 오유를 쉽 게 찾아낼 수 있다. 

흐름도에 서 리용되 는 기 하학적도형 들은 다음과 같다. 


기호이름 

기 호 

의 미 

시작 또는 끝 

广 ■_ 

、一 


— _ 少 

문제 줄이 의 시 작 또는 끝을 나타낸 다. 

자료입력 

/ / 

문제 풀이 에 필 요한 초기 자료를 넣 는다. 

처 리 기 호 




• 나 또 TT 여 러 개 의 처 리 내 용'문 효시 。 J ： 다 . 

판단기 호 

o 

비 교，판단되 는 내 용을 표시 한다. 

출력 기호 


--一- 


줄력 되 는 자료를 표시 한다. 

결 합기 호 

1 


) 

흐름선이 이 어 진다는것 을 표시 한다. 

함수호출 




함수를 i 줄한다. 

흐름선 

- ^ 

문제 줄이 흐름방향을 표시 한다. 


① 직 선형 구조 

구의 겁면적과 체적을 구하는 알고리듬을 흐름도로 작성하자. 

입 력 자료 : 구의 반경 R 

출력자료: 겉면적 S , 체적 V 

수학적모형화: S = 4 ttR 2 , V = 4/3 ttR 3 
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수학적모형화: n ^- 2로 나눈 나머 지(이 것 로~ 

다.)가 0이면 짝수，1이면 홀꼭 

흐름도: 


로그람에 서는 n mod 2로 



나 


- 블로크도 

블로크도는 흐름도와 같이 조종의 전달을 따로 밝히지 않고 포함구조만三 
알고리듬의 표현방법의 하나이다. 이것을 NS 도식이라고도 한다. 

기호들의 의미는 다음과 같다. 




두개 의 처 리가운데 서 조건판정 에 
따라 어느 하나의 처리를 진행 


여 러개의 처 리가운데서 조건판정 에 
따라 어느 하나의 처리를 진행 


반복 

구조 



먼저 조건을 판정하고 그에 
처리를 반복 



뒤에서 조건을 판정하고 그에 
처리를 반복 


1다라 • 


1다라 • 




















① 직 선형 구조 

반경이 요인 원에서 중심각이 120ᄋ 일 때 활등의 길이를 구하는 알고리듬을 블로 
크도로 작성하자. 

입력자료: 반경 R , 중심각 a = 120° 

출력자료 : 활등의 길 이 £ 

수학적 모형 화 : n = 7 t /180* a *R 
블로크도: 


R 입력， 

a <- 120 

公 — 71 

도 / 180* a *R 

£ 출력 



② 직 선형 구조 

두 수 a , b 의 값이 각각 3, 4일 때 두 수의 합을 계산하는 알고리듬을 블로크도로 
작성하자. 

입력자료: 두 수 a =3, b =4 

출력자료 : 합 S 

수학적모형 화 : S = a + b 

블로크도: 


a — 

- 3, b <- 4 

S — 

- a + b 

S 출력 


③ 갈래형과 순환형의 혼합구조 

30보다 작은 3의 배수를 구하는 알고리듬을 블로크도로 작성하자. 

입력자료: 자연수한계 30 

출력자료: 3의 배 수들의 모임 

수학적모형화 : x mod 3 = 0으로 되 는 모든 x 

블로크도: 
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련습문제 

1. 다음 문제들에서 입력자료와 출력자료를 찾고 수학적모형화를 진행하여라. 

1) 10명 학생 들의 수학성 적 이 있 다. 최우등생 수，우등생 수를 계 산하여 라. 

2) 60보다 작은 6의 배수를 모두 말하여 라. 

3) 우리 학급 학생들가운데서 제일 큰 학생의 키는 얼마인가? 

4) 우리 학급의 키측정자료를 큰 순서 대 로 배 렬하여 라. 

5) 30부터 50까지 의 자연수에 서 씨 수를 골라내 여라. 

2 . 다음 문제 의 알고리 듬을 작성하여 라. 

1) 두 점의 자리 표가 주어 질 때 두 점 사이의 거리를 구하여라. 

2) 웃반경，아래 반경，높이 가 주어 질 때 원틀대의 체적 을 구하여 라. 

3) 세 점의 자리표가 주어졌을 때 3각형의 면적을 구하여라. 

4) 한 변의 길이가 a 인 바른3각형의 내접원의 면적과 둘레의 길이를 구하여라. 

5) 길이가 a , b , c 인 세 선분이 3각형의 변을 이룰수 있는가를 판정하여 그 면적 
을 구하여 라. 

6) 1부터 100까지 자연수들가운데서 짝수들의 개수를 구하여라. 

7) 2010년 4월 15일 이 목요일 이라는것 을 알고 이 달의 임의의 날자를 입 력하면 그 
에 대 한 요일 을 출력하여 라. 

8) 어 떤 옹근수 표가 씨수인가，합성 수인가를 판정하여 라. 

9) 1부터 100까지 자연수가운데 서 씨수를 출력하여 라. 

10) 24 X 24 표를 계 단별로 구하여 라. 


곧# 터 상져 

알고 리듬 

알고리 듬은 중앙아시 아의 수학자 알리 호레 즈미 의 이 름에 서 유래되 였 다. 

그가 9세 기초에 쓴 수의 표기 법 과 산수연산규칙 에 관한 책 이 12세 기 에 라 
린어 로 번역되 여 유럽 에 전해졌는데 저 자의 이 름이 Algori 比 Lmi 로 잘못 표기 됨 
으로써 알고리 듬이 라는 용어 가 생겨 나게 되 였 다. 알고리 듬이 잘 작성 되 여 야 앞 
으로 콤퓨터에 주는 지령들이 잘 작성될수 있다. 따라서 콤퓨터가 문제를 잘 푸 
는가 못 주는가 하는것 은 알고리 듬을 얼 마나 잘 작성 하는가 하는데 관계 된 다. 

이 세상에는 어떤 문제에 대한 알고리듬을 찾기 위해 일생을 바친 과학자들도 
있 다. 세 상에 는 알고리 듬이 존재 하는 문제 도 있고 존재 하지 않는 문제 도 있 다. 또 
한 알고리 듬에는 효률 이 높은 알고리 듬도 있 고 효률 이 높지 못한 알고리 듬도 있 
다. 효률이 높은 알고리듬 즉 좋은 알고리듬은 기억기용량을 작게 쓰고 처리회수가 
될수륵 작은것 이 다. 처리회수가 작아야 콤퓨터에서 실행시간이 짧아지며 한 문제를 푸 
는데 쓰는 기 억용량이 작아야 다중과제 처 리콤퓨터 가 단번에 보다 많은 문제를 풀수 있다. 
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제 2 점. 프로그#연어# 年엇인가 


1. 프로그람작성언어 


1) 프로그람작성언어 

프로그람을 작성 하자면 그것 을 서 술하기 위 한 프로그람작성 언어 가 필요하다. 

사람들사이의 대화는 반드시 어떤 언어(조선어，영어，중어 등)를 가지고 진행된 
다. 사람들사이에 사용하는 이러한 언어를 자연언어라고 한다. 

마찬가지로 콤퓨터에서도 각 장치들사이 그리고 사람과 콤퓨터사이에 서로〈〈말》 
을 주고받자면 언어가 있어야 한다. 바로 이 언어가 프로그람작성언어이다. 프로그람 
작성언어는 콤퓨터가 수행하는 일을 서술하기 위한 언어적인 표현수단이다. 

2) 프로그람작성언어의 분류 

프로그람작성언어 는 크게 범 용언어 와 특수문제방향어 로 분류한다. 

(1) 범용언어 

범용언어는 말그대로 프로그람작성에서 널리 쓰이고있는 언어로서 발전정도에 따 
라 저급언어와 고급언어로 나눈다. 

① 저급언어 

저급언어는 를퓨터의 하드웨어에 얽매인 언어로서 기계어 (machine language ) 와 
아쎔블리어 (assembly language ) 로 나눈다. 

기계어는 콤퓨터의 각 장치들사이에 통하는 언어이다. 

기계어로 작성한 프로그람(기계어프로그람)은 하드웨어가 직접 실행시킬수 있다. 

기계어는 0과 1의 약속된 수자렬로 구성되여있으며 하드웨어를 알아야만 프로그 
탐을 작성할수 있기때 문에 프로그람을 작성 하고 다투는데서 까다롭고 품이 많이 든다. 

기계어의 부족점을 덜기 위하여 명령이나 기억주소를 어떤 영어문자로 바꾸어 리 
용하는 언어 가 아쎔 블리 어이 다. 

② 고급언어 

고급언어 는 콤퓨터 에 얽매이지 않으며 자연언어 에 가까운 언어 로서 프로그람을 작성 하 
기가 편리한 언어 이 다. 고급언어는 그의 구성에 따라 수속 S 언어와 비수속 S 언어로 나눈다. 

- 수속형 언 어 (procedure oriented language ) 

수속형 언어는 콤퓨터 가 해 야 할 일을 순서 대 로 표시하는 언어 이 다. 따라서 이 언 
어 로 작성한 프로그람은 시 작과 끝이 있으며 시 작에 서 끝까지 집 행 과정 을 1렬 로 줄지 
어놓을수 있다. 

대표적 인 언어로서 C , Basic , Pascal 등을 들수 있다. 

- 비 수속형 언 어 (nonprocedural oriented language ) 

이 언어는 인간의 사유원리에 기초하여 어떤 사물현상에 대한 판단을 표현하는 언 
어 이 다. 여 기 에는 론리형 언어，함수형 언어，객체지향언어 가 있다. 

여 러 가지 언 어 를 리 용하여 두 수 a 와 b 의 더 하기 를 표시 해 보자. 
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여러가지 언어를 리용한 두 수의 더하기 


언어 

조작^ \ 

저급언어 

고급언어 
(c 언어례) 

기 계 어 

아쌤 블리어 

3. ~ 8 

1011100 Q 0000000000001000 

조작 Y 코드 삯 

MOV AX , 8 

3. — S 

b = 5 

10111011 0000000000000101 

MOV BX , 5 

b = 5 

a + b 

0000000111000111 

ADD AX,BX 

a + b 


표에서 볼수 있는바와 같이 기계어는 1세대콤퓨터가 사용한 언어로서 콤퓨터가 
직접 리해할수 있는 0과 1의 2진수로 명령을 표현하고있다. 그러므로 기계어로 작성 
한 프로그람을 실행할 때에는 번역할 필요가 없기때문에 실행속도가 빠르지만 콤퓨터 
의 종류에 따라 사용하는 명령이 다르므로 사람들이 리해하기 어렵다. 

아쌤 블리 어 는 기 계 어 대 신 그와 1:1로 대 응되 는 리 해 하기 쉬 운 기 호로 명 령 을 만 
든 언어 이 다. 그러므로 기계 어보다는 좀 리해 하기 쉽지 만 콤퓨터내부의 등록기를 직 접 
조작하는것으로 하여 전문가가 아니면 역시 프로그람작성이 힘들다. 

그러 나 고급언 어 로 작성 된 프로그람은 우리 가 흔히 리 용하고있는 수학적 인 기 호로 
구성 된것 으로 하여 리해 하기 쉽다. 

프로그람언어 ᅮ ■聲 저급언어 一 I —► 기계 어 - ^<1 세대 언어〉 

—► 아쎔 블리 어 —— ► <2세 대 언 어〉 

ᄂ 고급언어 — |__ ►수속 형언어 __ ►론리 형언어 

一一 ► 비 수속형 언 어 - ►함수 형 언 어 

一一 ►객 체 지 향언 어 


(2) 특수문제방향어 

특수문제방향어는 특별히 제한된 범위의 문제들을 처리하기 위한 전용언어이다. 


2. C 언어에 대한 개념 


1 ) C 언어의 특징 

C 언어 는 현재 가장 많이 사용되 고있는 프로그람작성언어 이 다. 

C 언어 란 이름은 B 언어 다음에 나온 언어라는데로부터 붙여진 이름이다. 

초기 에 C 언 어 는 조작체 계 Unix 를 서 술하기 위하여 1972년 에 개 발한 고수준프로 




































그람작성언어 이 다. Unix 조작체계는 체계의 90%에 해 당되는 부분을 C 언어로 서술하 
였다. 그러므로 C 언어 를 체계 개 발언어 라고도 한다. C 언어는 체계 개 발을 위하여 만들 
어 진 언 어 라는데 로부터 Basic 나 Pascal 과 같은 고수준언 어 의 특징 을 가지 면서 도 아 
쨈 블리 어로만 가능한 처 리 까지 도 자유롭게 서 술할수 있는 능력 을 가지 고있 다. 

C 언어의 _징은 다음과 같다. 

① 언어표현능력 이 강하다. 

C 언어는 비트조작이나 주소관리 등 극히 세부적인 처리가 강하기때문에 아쌤블리 
어 를 대 신 하여 여 러 가지 체 계 프로그 람과 응용프로 그 람을 작성 한다. 

② 여러가지 형의 자료구조를 설계할수 있는 능력을 가지고있다. 

③ C 언어는 매우 간결하고 콤파일러가 작다. 

다른 언어 에서 Begin 〜 End 로 표시하는것 을 { 와 } 으로 ， If a〉b then 〜 else 
를 3항연산자를 리 용하여 간결 하게 표시 한다. 

또한 프로그람실행과 관련한 자원도 적으며 기억공간도 적게 차지한다. 

④ 언어가 만드는 코드의 질이 매우 높다. 

C 언 어 는 아쌤 블리 어에 대 비할만큼 코드효률 이 높다. 

⑤ 이식성이 비교적 좋다. 

C 언어 로 작성한 프로그람은 수정하지 않거 나 혹은 약간 수정하면 완전히 다른 환 
경에 옮겨 실현할수 있다. C 언어의 결함은 연산자의 우선권종류가 너무 많으므로 기 억 
하기 힘 들며 자료형검 사능력 이 약하고 비 교적 쉽 게 절 환시킬 수 있 으므로 안전성 이 높 
지 못한것이다. 

2) C 프로그람의 구조 

C 언어 로 프로그람을 작성하려 면 C 프로그람의 구조를 잘 알아야 한다. 

례로 다음과 같이 통합개발환경 《삼태성》에서 주어지는 례프로그람을 통하여 그 
구조를 알아보기로 하자. 

« 시 작》- « 응용프로그람》ᅳ « 프로그람개 발》- « 통합개 발환경〈〈 삼태 성》 2. 0》 
-> 《 C / C ++프로그람개 발도구》를 실행 한다. 


ᄉ 대규모과학기술계산한경《병진》10 
f C 내나 B 내 i 암기 2,5 !：f 보조프로그담 ► 

제■신 ^ ■"리 ^ 

▲ 떠，떼구 

s ： _ 나 ■ 및 도- ^ 나녀，『ᅳ . 4. 프로그맘작■도서 

속 유회오락 / |gjgggHHH|BM 

0 민터네트와망 ► 

ᄅ Windows 응용프로그람' ► 

Windows 탄경지원프로그람 ■ ► 

S 나의 등록부 

.쪘 도관 

必 상 조종판 
回 대화접속탈최 


응용프로그 
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그러면 《삼태성》 ( C / C ++ 프로그람개발도구)창문이 펼쳐진다. 



차림표띠에서 《프로젝트(£)》—《새 프로 
젝 트 (인)》지 령 을 실 행하여《 새 로운 프로젝 트 창 
조》대 화칸을 펼친다. 


프로젝트 £) 

구축 0=) 오유제거 장문(또 

|_ A ᅢ 프로젝 

트맨 )… _ J 


일반 


프로젝트영판들 (山 


0 c 


간 ■ 만■한 HgIIo world 


장지 구동프로그밤 

© 》 C 十十 


〕 프로젝트 열 기 (: 으 ) … 

최근 프로젝트열기 

V 다른 1:1 식의 프로젝트 _i 기 ( 丄 ) 


Ibml&li - 소예먹 


대3기 보 ?; i 7 igfj ]| 도 gy 


편 ■장 항 >t 다 I M 

계 + 하과'! Enter 건古 +르십시 오.! 


■ ibinfsh 


C 언 [H 로 . 간 ■ 단란 " Hello world 프로그람■들 만 
듭니다 ■. 


□ 모든 프로젝트형판들 보기 (]) 


—소서 


응용프로그람이 _(M): 

hello| 




위지 位 ): 

/root/ 

函 


초 I 종위지 : /root/hello 




羅 .두ᅵ로 


© 다음맨 ) 


H 취소 
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왼쪽의 〈〈 프로젝트형판들 ( Y ) 》칸에서 c 를 찰칵하여 나타나는 〈〈 간단한 Hello 
world 프로그람》을 선택한다. 이때 오른쪽칸에는 프로그람의 실행결과와 그에 대한 
해설문이 제시된다. 아래 의 《속성》부분에서 《응용프로그람이 름(인)》칸에 이제 작성 
할 프로그람의 이름 례로 hello 를 입력하고《위치 ( Q )》 칸에 프로그람을 보관할 등록 
부이름을 입력하면 《최종 위치》에 / root/hello 와 같이 그 위치가 표시된다. 

《다음 ( N )》 단추를 찰칵하여 다음단계로 넘어간다. 



〈〈다음 ( N )》 단추를 찰칵하여 다음단계로 넘어간다. 
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마지 막으로〈〈끝내 기》단추를 찰칵하면 개 발도구창문에 다음과 같이 간단한 C 프로 
그람이 제시된다. 



그림에서 보는바와 같이 C 프로그람은 전처리부，함수의 형선언부，함수정의부로 
이루어지며 또한 변수정의부가 놓인다. 

우의 례 프로그람에 서 #include < stdio . h >, ^include < stdlib . h > 와 같은 문장을 
전처리문이라고 한다. 전처리문은 말그대로 프로그람의 번역전에 처리되는 명령문이다. 
여기서 stdio . h , stdlib . h 는 머리부파일의 이름이다. 

머리부파일은 대체로 / usr/include 보조등록부에 위치한다. 바로 이러한 머리부 
파일의 삽입이나 상수정의，형정의를 진행하는것이 전처리부이다. 

대역변수정의부에서는 대역변수가 정의된다 . 대역변수는 프로그람안에 있는 모든 
함수들에서 공동으로 리용되 는 변수이 다. 대 역변수정 의 부는 전처 리 부다음에 함수의 형 
선언부앞에 놓인다. 

례 프로그람에서 int main(int argc，char * argv []) 는 함수 main 이 옹근수형 이 라 
는것을 선언한것이다. 이와 같이 함수의 형선언부에서는 함수들의 형태를 선언한다. 

함수정 의 부에 서 는 함수의 본체 를 정 의한다. 
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C 언어 는 수속형 언어 로서 C 프로그람은 어 떤 독자적 인 기 능을 수행하는 명 령 문들의 
묶음인 함수들로 이루어져있다. 

여러개의 함수들가운데서 제일 먼저 실행되는 함수를 주함수라 고 한다. 

C 프로그람은 적 어도 한개의 함수를 가져 야 하며 그것은 반드시 주함수이다. 

주함수의 이름은 main 으로 되 여있으며 형식은 다음과 같다. 

main ( [int argc , char * argv []]) 

{ 

명 령 블로크 ; 

} 

C 언어 로 작성 된 함수들은 시 작과 끝이 { } 기 호로 둘러막혀 야 한다. 


3 . C 프로그람의 개발과정 


① 편집 기 를 리 용하여 원천프로그람 ( source ) 을 작성 한다. 

원천프로그람은 프로그람언어 를 리 용하여 작성 한 프로그람을 말한다. 여 기 에서 는 
C 언어로 작성된 프로그람을 말한다. 

우리 식 조작체계 《붉은별》에서는 앞에서와 같이 통합개발환경 《삼태성》의 
C / C ++ 프로그람개 발도구창문을 리 용하거 나《 시 작》ᅳ《 응용프로그람》ᅳ《 본문편집 기》 
를 실행하여 기동되는 본문편집기에서 원천프로그람을 작성할수 있다. 

앞에 서 우리 는〈〈 간단한 Hello world 프로그람》에 이 름을 hello 라고 달았는데 이 
프로그람은 hello . c 라는 파일이름으로 보관된다. C 언어로 작성된 원천프로그람들은 
확장자가 c 로 된 파일 이 름으로 보관된 다. 파일열 람기 에 서 〈〈 나의 등록부》를 열 어보면 
hello 라는 이 름을 가진 등록부가 새 로 생겨난것 을 볼수 있 다. 



화 貧© ll« 

o, r 、 

我 乂 

1 

\ 1^1 리 

: & 위지 C 으 ): ^ 5y5tem:/home 



system:/home - ni ■ 일 ™ 즘!■기 


n^cu 2 SCE ) 보기[년 가기년) 책갈피® 도구( I ) 설정년) 장문 [ w ) 도움말 


☆ 


© 


£0 




在 


♦ 


나므등록부 


『나의 제계 

年| - 나의 믐막 
© i Desktop 
© ^ihello 

命®?나의 콤퓨 a 
리용자듬특부 
©ᆻ 망자원 
©핵 v 설정 
© 회수들 


ni aii 卞 」 I _hi 



U °| 믐막 



hello 


< SE>Hay 

< gg>Hay 


<s 

Desktop 


t Kiid ᅢ 
install 

lan 요 ho 
htub 田 ar 


anaconda-ks 

cfg 
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/ hello/src 등록부를 열어보면 hello , c 파일이 있다. 

② 원천프로그람의 번역 및 련결을 진행한다. 

프로그람을 편집한 다음에는 그것을 번역 및 련결하여 실행가능한 파일로 만들어 
야 한다. 

앞에서 작성한 《간단한 Hello world 프로그람》의 번역 및 련결과정을 보기 
로 하자 • 

C / C ++ 프로그람개 발도구창문의 차림표띠 에서 《구축(느) >ᅳ《파일 콤파일》지 령을 
실행하면 프로그람에 대한 번역을 진행하면서 창문의 아래쪽에 다음과 같이 통보가 제 
시된 다. 



0〔d 7roGt/hello/debug/5rc' && WANT_AUTOCONF_2_5=" 1" WANT_AUTOMAKE_ 1 _6= 11 1 11 gmake -k hello.lo 
c ■콤 ill ■일중 hello , c ( gee ) 
c ■콤 HI ■일중 hello.o Cgcc) 

콤 li ᅡ일중 null [ qcc ) 

성공 예 


■1 응용프로그 담 

들보 

S 여레 I ᅡ일 [HI 서 탐색 

표쪽 n ■색 

교체 

ki 문제 
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이 통보에 서 보여주는바와 같이 C / C ++ 프로그람개 발도구창문에 서 작성 된 C 프로그 
탐은 Linux 조작체 계 배 포판들에 서 제 공되 는 C 를 위한 ANSI 표준문법 을 가지 고있는 
64 bit 번역 기인 gcc(GNU C Compiler ) 를 리용하여 번역 을 진행한다. 
gcc 는 대체 로 / usr/bin 이 나 / usr / local/bin 등록부에 기 억되 여있다. 
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C / C ++ 프로그람개 발도구창문에 서 처 음으로 프로그람을 작성 하고 차림 표띠 에 서 

《구축(느) >ᅳ《파일 실행》지 령을 실행하거 나 도구띠 에서 프로그람실행 단추 텔를 찰 
칵하면 다음과 같은 통보가 제시된다. 



여기서 〈〈실행》단추를 찰칵하면 우에서와 같이 프로그람에 대한 번역 이 진행되고 
번역이 성공하면 통보가 제시되며 조작탁창문에 결과가 현시된다. 
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대화접속 3 S 보기 책갈피 설3 도움말 


한 3 합니 [M !! 

계속하려면 Enter 건들 누르십 시오! 




屬 


* 7bin/5h 


A] 
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/ hello/src 등록부에 서 hello , c 파일 을 두번찰칵하면 다음과 같이 본문편집 기 창문 
에 앞에서 작성한《간단한 Hello world 프로그람》이 입력되여있는것을 볼수 있다. 



ro ot/h eio/s rc/h elfo, 


ni ■일 £ E ) 33 ( E ) 설 도응말[出 



因 函 ■ 感 卜%，다 





모•요 유•요 유•요 J •요 모•요 모•유 유•요 요•요 모•요 모수요 요소요 유•요 유수요 모소강 유•요 모•요 Jffj 

들합개발한 § 《삼引 I 성 》 f c / c 十十 프로그담개발도구) * 


中中中 


■+■ ^부 ■， J 우. ") 유 ■ ■유^. 卜 유 1 . J 우- " j^ B 우 ■ ■/우， ") 유. ^유 1 유 ^유 ■ "+■ B ^^ B ■! 수 ■ a ^ 유 ^유. ^부. 유 ^유 1 . J 유-，■!유 ■ "+■ B ^^ B ■+■ B ^^ B ■유^ i^^i ^우 1 ") 우 ■， J 부- ■욕^ ^유 1 유 ^부- ， J 우. B j^ B ■+■ ■+■ ■ 


#ifdef HAVE_CONRG_H 
#include <config.h> 

#endif 

#include <5tdio.h> 

#include <stdlib,h> 

int mainfint argc, char *argv[]) 

{ 

print " 탄 3 합니다 ! !!V ， T): 


return EXIT SUCCESS; 


} 


조작탁창문에서 cd hello/src 지령을 입력하고 Enter 건을 눌러 /src 등록부를 작 
업등록부로 만든다. 다음 gcc -o hello hello , c 지 령 을 입 력 하고 Enter 건을 누르면 
hello , c 파일 을 번 역하여 hello 라는 실 행파일 로 보관한다. 이 때 hello 라는 파일 은 현 
재 작업등록부에 보관된 다. 
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실행파일의 실행은 앞에 ./ 를 쓰고 그뒤에 실행파일의 이름을 쓰면 된다. 

현재 작업 등록부에서 ./hello 지령을 실행 하면 앞에서 만든《간단한 Hello world 
프로그람》이 실행된다. 

③ 오유수정 도구를 리용하여 오유를 수정한다. 

번역과정에 문법적오유가 검출되면 오유통보문이 현시되면서 처리가 중지되며 결 
과 실행파일 이 생성 되지 않는다. 이때 에 는 다시 편집 기 를 기동하여 오유통보문에 따르 
는 오유원인을 찾아 프로그람을 수정하여 다시 번역 을 진행한다. 

의 형태 

• 문법적오유: 언어에서 제정한 규칙에 어긋나게 표현된 부분으로서 이것은 번역 
시 에 그 류형 에 따라 행번호와 오유통보문으로 통지 된 다. 

• 론리적오유: 프로그람언어 에서 제정한 규칙 에 는 어긋나지 않지 만 프로그람적 요 
구를 정확히 실현하지 못하게 하는 오유를 말한다. 

이러한 론리적오유는 오유수정도구를 리용하여 발견하고 제거할수 있다. 

Linux 배포판이 나《붉은별》조작체계에서는 오유수정도구 gdb 를 제공한다. 


_ 6:上아욱기 

\ 

gdb 에서 많이 리용되는 지령 I 

| 

1 | 

| - list 지령은 오유수정도구안에서 원천프로그람을 볼수 있게 한다. | 

1 -print 지령은 변수검사지령으로서 프로그람에서 리용되는 변수들의 내용을 보 | 
j 기 위한 지령이다. | 

j - run 지령은 프로그람을 실행시키는 지령이다. I 

j - break 지령은 지정된 행이나 함수에 중단점을 설정하며 clear 지령은 반대로 | 

I 중단점을 해제하는 지령 이다. i 

| - info 지 령 은 프로그람의 파라메터정 보나 중단점，출력설정 들을 볼수 있게 하 I 

i 는지령이다. I 

j - set 지 령 은 변수들의 값을 설 정 하는 기 능을 수행 한다. I 

| I 

j - disassemble 지 령 은 프로그람을 아쌤 블리 어 로 현시 한다. | 

1 - help 지 령 은 gdb 에 대 한 도움말을 현시한다. | 
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통합개발환경《삼태성》설치법 

1. 설치시 주의사항 

《삼태성》 2.0 은 《붉은별》 2. 0( 사용자용체 계)에서 동작한다. 

주기억 128 MB 이 상，동작주파수 1 GHz 이 상，하드디 스크용량 20 GB 이 상을 
가진 Pentium III 이 상의 콤퓨터 에 서 설 치하여 야 한다. 

2. 설치 

CD 로 또는 하드디 스크에 서 설 치할수 있 다. 

《삼태성》 2.0 이 들어 있는 등록부에서 development , repo 파일을 두번찰칵 
한다. 그러 면 통합개 발도구《 삼태 성》 2.0 설 치 대 화칸이 현시 된 다. 

대 화칸에서 〈〈 다음》단추를 찰칵하면 쏘프트웨 어 선택단계 로 넘어 간다. 



쏘프트웨어묶음들을 선택한다. 개발도구의 충분한 기능을 리용하려면 모두 
선택을 진행하여야 한다. 《다음》단추를 찰칵하면 설치될 쏘프트웨어묶음과 설 
치용량이 현시된다. 〈〈다음》단추를 찰칵하면 실제적인 설치작업이 진행된다. 
설치가 완료되면 성과적으로 설치되였다는 통보가 현시된다. 

마지막으로〈〈완료》단추를 찰칵한다. 
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제 2 장. 4#찬 르르그#작성 

제1점. 年 4의 합계산 


이 절에서 는 두 수의 합을 구하는 프로그람작성 과정 을 동하여 C 언어 의 기 본기 호 
와 구성요소들을 학습하기로 한다. 

두 수 3과 4의 합을 계산하는 알고리 듬을 만들자. 

① 시작 

② a — 3， b — 4 

③ c ^- a+b 

④ c 출력 

⑤ 끝 
블로크도: 



이 프로그람을 C / C ++ 프로그람개 발도구창문에 서 작성하면 다음과 같다. 
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실 행 단추 © 를 찰각하면 조작탁창문에 결과가 현시된다. 



우의 프로그람에 서 쓰인 모든 기 호들은 C 언어 의 기 본기호에 속한다. 

一 C 언어의 기본기호 

① 영어문자: A , B , C , D , •••, Z ； a , b , c , d , …， z 

② 수자: 0，1，2，3，4，5，6，7，8，9 

③ 기호: !% ᆻ & *()+_={} | ~[ ] \ ； 

4 ‘‘ : < 〉? ， . / # 

- 구성요소 

우의 례에서 보는바와 같이 프로그람은 모두 여 러개의 명 령 문들로 이루어져있으며 
명령문은 또한 개개의 구성요소들로 이루어진다. 

① 이름 

이름은 상수나 변수，함수，표식 등 프로그람에서 사용되는 매개 요소들을 식별하 
기 위하여 주는 기 호들의 렬이 다. 따라서 프로그람안의 매 개 요소들은 이 름에 의하여 
식별된다. 이름에는 표준이름과 사용자정의이름이 있다. 

O 표준이름 

C 언어처 리기 가 미 리 정의 하고 관리하는 이름으로서 여기 에는 표준자료형이름，표 
준상수이 름，표준변수이 름，표준파일 이 름 등이 있다. 표준이 름은 미 리 정의되 여있기때 
문에 사용자들이 따로 정 의하지 않고도 리용할수 있 다. 

ᄋ 사용자정의이름 

사용자정의이름은 사용자들이 정의해서 C 언어처리기에 알려주고 리용하는 이름을 
말한다. 함수나 변수 등의 이름은 프로그람작성 자가 임의 로 정의할수 있다. 

O C 언어의 이름짓기규칙 

• 이름은 영어문자나 또는 밑선으로 시작될수 있으며 그뒤에는 임의의 문자나 수 
자 또는 밑선을 놓을수 있다 

• 대문자와 소문자는 각각 서로 다른 이름으로 해석된다. 례로 Index 와 index 
는 각각 서로 다른 이름으로 된다. 
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• 이름은 수자로 시작하지 말아야 한다. 

• 이름은 예약어와 같지 말아야 한다. 

c 언어에서 이름은 대체로 소문자를 많이 쓰며 대문자는 상수들과 일부 특수기호 
를 표현하는데 리용된다. 그러므로 프로그람을 작성할 때 될수록 이름을 소문자로 작 
성하여 야 한다. 

② 예약어 

예 약어란 미 리 약속된 단어로서 C 언어가 의미를 미 리 정해놓은 단어를 말한다. 

J C 언어에 정의되여있는 예약어 、 

asm, auto, break, case, char, const continue, default, do, 
double, else, enum, extern, float, for, goto, if, int, long, 
register, return, short, signed, sizeof, static, struct, 
switch, typedef, union, unsigned, void, volatile, while 

、 _ C 

③ 설명문 

설명문이 란 프로그람실행 과는 관련이 없는 문자렬로서 프로그람작성 자들이 명령문 
이나 함수，변수들에 설명을 달아주는것을 말한다. 

설 명 문은 프로그람명 령 문과 구별 하기 위하여 기 호 /* 로 시 작하여 */로 끝난다. 
번역프로그람은 이 부분을 콤퓨터 가 아는 기계 어 로 번역하지 않는다. 

두개 빗 선 //도 행단위 설 명 문으로 리용한다. 

④ 분리 기호 

C 언어 에서 리용되 고있는 분리 기호들은 다음과 같다. 



네봐린나상 

정보과학분야의 국제상은 없는가，있다면 어디에서 취급하고있는가 하는 물 
음을 가지는 학생들도 있을것 이다. 

1980년대에 들어와 네봐린나상이라는것이 제정되였는데 이것은 정보과학의 
수학적측면에 관한 업적 을 대 상으로 하여 1982년이 래 국제수학자회 의때마다 1명 
에게 수여되고있다. 수상자이름은 국제수학자회의 개회식에서 발표되고 수상식 
이 진행된다. 

국제수학련맹 은 유네 스코의 자매기 관인 국제 학술련맹 에 속하는 조직 이 며 수 
학분야의 국제협력을 추진하는 기관으로 되고있다. 국제수학련맹은 국제수학자 
회의를 4년마다 개최한다. 1988년도 국제수학회의는 베를린에서 열리였으며 
2002년에 다음번 회의가 열렸다. 
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제 2 점. 年 4의 평균값계산 


이 절에서는 두 수의 평균값을 계산하는 문제를 동하여 변수와 상수 그리고 자료 
형에 대하여 학습하도록 한다. 

두 수 3과 4의 평 균값을 계산하는 알고리 듬을 만들자. 

① 시작 

② a — 3， b 슨-4 

③ c —_( a + b )/2 

④ c 출력 

⑤ 끝 
블로크도: 



프로그람의 실 행전기 간 변하지 않는 수인 즉 3과 4는 옹근수형상수이다. 


1.상 수 


수학에서 는 문제물이과정 에 항상 변화되 지 않는 값을 상수라고 하는데 프로그람작 
성에서도 그 의미는 같다. 

상수란 프로그람이 실행되는 전기간 변하지 않는 값(수나 문자렬)을 말한다. 

C 언어 에서 모든 상수는 크기 와 형 을 가질뿐 문자렬상수를 제외 하고는 기 억기의 
주소를 가지지 않는다. 즉 기억기에 기억되지 않는다. 

상수는 크게 수값상수와 문자 및 문자렬상수로 나눈다. 

1) ^값상수 

수값상수는 옹근수형상수와 실 수형 상수로 분류된 다. 

① 옹근수형상수 

옹근수형상수들은 보통 10진수로 표시한다. 그러 나 필요에 따라서 2진수，8진수， 
16진수 등 임의의 진수로 표시할수 있다. 

8진수는 젓 머 리 에 영 어소문자 o 를 붙이 며 0부터 7까지 의 수자를 사용한다. 례 를 
들어 0127은 10진수 127이 아니 라 8진수 127(=87 10 )이 다. 

16진수는 첫머리에 Ox 를 붙이며 0부터 9사이의 수자와 A , B , C , D , E , 묘의 영어문 
자를 사용한다. 례를 들어 0 x 100 은 10진수 100이 아니라 16진수 100(=256 10 )이다. 
long 형의 옹근상수인 경우에는 수의 뒤끝에 L 또는 I 표식 을 덧붙인다. 


례 1: ol 5 L (8 진수)， 13 L (10 진수)， 0 xFFL (16 진수) 
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② 실수형상수 

실수형상수는 수학에서 소수점 이 있는 수와 같다. 

실 수형 상수에 는 고정 소수점 수형 식 과 류동소수점 수형 식 의 두가지 가 있 다. 

실 수형 상수의 표시 형 식 : 

mmm. nn [ekkk] 
mmm.nn : 결수부 
kkk : 지 수부 

e :밑수 10 

고정소수점수형식: 

123.56 ， 3.141592 

류동소수점수형식: 

12. 356e2 (=12. 356 X 10 2 )， 1235. 6e_2 (=1235. 6 X 10' 2 ) 

2) 문자 및 문자■상수 
① 문자상수 

문자상수는 ’ ’안에 넣 는 문자이 다. 

E1I 2 ： ， a ，， T ， ’c ， 

문자상수는 실제 적 으로 아스키코드를 의 미하므로 례에서 문자상수 ’a’ 는 옹근」 
96 (0x61) 과 같다. 마찬가지로 문자상수 ’1’ 은 옹근수 48 이므로 수자 1 과 차이가 있다. 
줄력 조종기호로 쓰이 는 문자상수들은 빗 선(\) 으로부터 시 작한다. 

C 언어 에서 리용되 는 특수한 문자상수(조종문자)들은 다음과 같다. 



기 능 

아스키 코드 

\0 

령문자로서 문자렬 의 끝을 나타냄 

0x00 

\a 

종소리 (bell) 

0x07 


뒤 걸 음치 기 (backspace 건의 기 능과 같다. ) 

0x08 

\t 

행은 그대로 있으면서 유표를 Tab 만큼 이동한다. 

0x09 

\n 

행바꾸기 를 진행(유표의 렬위 치 는 변화되 지 않는다. ) 

OxOA 

\f 

페지바꾸기를 진행 

0x0C 

\r 

복귀 한다. (Enter 건의 기 능과 같다. ) 

0x0D 


② 문자렬상수 


문자렬 이 란 하나이 상의 문자들의 묶음을 말한다. 문자렬상수는 “ ”안에 포함된 기 호 
렬이 다. 

례 3 ： “Korea is One!” 

“K” 

“This string is longer than that\n” 

“124355676 ，， 
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문자렬상수는 다른 형태의 상수들과는 달리 주기억기안에 기억되며 따라서 기억주 
소를 가전다. 

문자렬상수는 주기 억기 에서 련속적 인 바이 트들에 차례로 기 억되기때문에 문자렬상 
수의 첫 시작주소만 알면 해당 문자렬상수의 위치를 알수 있다. 

문자렬상수에는 체계에 의하여 문자렬의 끝에 문자렬끝을 의미하는 령문자 \0이 
자동적 으로 삽입 된 다. 따라서 문자렬 상수의 실 제 크기 는 문자렬 상수에 포함된 실제 문자 
들의 개수보다 1개 더 큰 값으로 된다. 례로 “ abc ” 라면 문자렬상수 abc 의 실제크기는 
4이 다. 

2.변수 


앞의 알고리 듬에 서 a , b , c 는 변수이 다. 초기 값을 다르게 주면 다른 값이 들어간 
다. 그러면 변수에 대 하 여 보기로 하자 . 

우리는 수학에서 변수라는 말을 많이 하여왔다. 수학에서의 변수는 변하는 수를 
나타내는 문자를 말한다. 

프로그람에서 변수의 개념은 수학에서의 개념과 비슷하다. 즉 프로그람에서 변화 
되는 값을 가질수 있는 문자 또는 문자렬을 말한다. 

콤퓨터 와의 관계 속에 서 고찰해볼 때 변화되 는 자료를 보관하기 위한 장소는 주기 
억 기 이 다. 

기억기에 보관된 자료는 기억주소에 의하여 식별된다. 또한 프로그람에서 변화되 
는 값은 문자렬로 구성된 이름에 의하여 식별된다. 그러므로 프로그람에서의 변수는 
한마디 로 주기억기의 주소와 같다고 말할수 있다. 

변수는 그 변수에 값주기하려 는 자료의 형 에 따라서 다시 말하여 변수에 값주기 될 
자료의 크기 에 맞게 기 억공간을 차지할수 있다. 자료형은 뒤 에서 학습한다. 

프로그람에서 리용되는 변수의 선언은 자료형을 동반한다. 

일반형식: 


〈자료형이 름〉 <변수이 름1〉，<변수이 름2〉，…，<변수이 름 n 〉; 


함수 및 변수의 이름은 프로그람작성 자가 임의 로 정의할수 있다. 

• 이름은 영어문자나 또는 밑선으로 시작될수 있으며 그뒤에는 임의의 문자나 수 
자 또는 밑선을 놓을수 있다. 

• 대문자와 소문자는 각각 서로 다른 이름으로 해석된다. 

C 언어에서 이름은 대체로 소문자를 많이 쓰며 대문자는 상수들과 일부 특수 
기 호를 표현하는데 리 용된 다. 그러 므로 프로그람을 작성 할 때 될수륵 이 름을 
소문자로 작성 하여 야 한다. 

• 이름은 수자로 시작하지 말아야 한다. 

• C 언어 와 약속된 체 계변수，예 약어，표준함수들과 같은 이 름으로 짓 지 말아야 
한다. 
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ai ： 


Index 


기 


idex 

SetVideoMode 
_abc 
_9 Label 
Label 9 j 


> 舍다' 


9 _Label 

*abc 


j > 옳지 않다. 


변수의 분류는 상수의 분류와 같다. 

C 언어의 변수에는 구조체형변수가 있다. 

이 부분에 대 하여 서 는 뒤 에 서 보기 로 한다. 

3.자료 형 


1) 자료형에 대한 일반개념 

어떤 자료를 보관시키는데 얼마만한 기억용량이 필요한가를 결정하는것이 콤퓨터 
에 서 의 자료형 에 대 한 개 념 이 다. 

자료형이란 말그대로 자료의 형태로서 자료를 담을수 있는 그릇의 크기 다시말하 
여 프로그람실행시 자료를 기억시킬수 있는 기억기의 크기를 표현한것이다. 

기억기에 할당된 크기에 의하여 자료를 보관할수 있는 값범위가 결정된다. 

가령 lbyte 의 기억크기가 확보되였다면 2 8 = 256이므로 부호 없는 옹근수인 경우 
에 는 0~255사이 의 값을，부호있는 옹근수인 경 우 -128-127 사이 의 옹근수를 기 억 할수 
있다. 이렇게 놓고볼 때 자료형은 자료를 기억시킬수 있는 값범위라고 말할수 있다. 

프로그람을 작성할 때 에는 여 러 가지 종류의 자료(례하면 수값이 나 문자 등)들을 
취급하게 된다. 

례로 두 수의 합을 구하는 프로그람을 작성 할 때 int a , b , c 라고 하였는데 이것 
은 변수 a , b , c 가 옹근수형변수라는것 을 선 언한것 이 다. 즉 이 변수들은 옹근수형 의 
값들만을 취 급하며 이 변수들에 기 억 되 여있는 값들을 옹근수로 해 석하라는것 이 다. 그 
러면 그 자료형들을 구체적 으로 보기로 하자. 
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2) 표준자료형 

표준자료 형이 란 체계 개 발자들에 의하여 미 리 정의된 자료형 을 말한다. 

C 언어가 제공하는 표준자료형은 수값자료형들의 모임으로서 크게 소수점 이 있는 
가，없는가에 따라 옹근수형과 실수형으로 구분할수 있으며 부호가 있는가 없는가에 
따라 부호있는 수값형과 부호 없는 수값형으로 나눈다. 

부호 없 는 수값형 은 형 이 름앞에 예 약어 unsigned 를，부호있 는 수값형 에 는 예 약 
어 signed 를 붙인다. 생략하면 부호있는 수값형이다. 

① 옹근수형 

옹근수형 은 소수점 이 없는 자료를 기 억할수 있는 형 으로서 그것 이 취 할수 있는 수 
값범위에 따라 char 형， short 형， int 형， long 형으로 나눈다. 

매 옹근수형에 따르는 수값범위와 기억기에서 차지하는 바이트수，자료형의 이름 
은 다음과 같다. 


형 이름 

부호 없는 수값범위 

부호있는 수값범위 

기 억 기 크기 
(byte) 

char 

0-255 

-128-127 

1 

short 

0〜65 535 

-32 768-32 767 

2 

int 

번역기에 따라 다르다. 즉 16bit 번역기이면 short 형과 
같고 32bit 번역기이면 long 형과 같다. gcc 번역기는 64bit 
번역 기이므로 8byte 크기 를 확보한다. 


long 

0-4 294 967 295 

-2 147 483 648-2 147 483 647 

■ 


례 1： 다음의 자료들은 어떤 형을 선택하여 야 하겠는가? 

a = 356 : unsigned short 형 

b = 34765 : unsigned short 형 

c = -128 : ( signed ) char 형 

d = 21475183 : long 형 

② 실수형 

실수형은 소수점 이 있는 수를 보관하는 자료형 으로서 그것 이 취 할수 있는 값범위， 
유효자리 수에 따라 float 형， double 형 ， long double 형 으로 나눈다. 

실수형 에 따르는 수값범위 와 유효자리수는 다음과 같다. 


형 이름 

값범위 

유효자리 수 

기 억 크기 

float 

3.4E38 

7 

4 

double 

1.7E308 

15 

8 

long double 

1.2E4 932 

19 

10 
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이상의 기본자료형들을 묶어보면 다음의 표와 같다. 


자료형 이 름 

변형된 이름 

크기 

표시 범 위 

char 

unsigned char 

8 

-128-127 

int 

signed 
signed int 

번역기에 따라 
다르다. 


short 

short int 

signed short 
signed short int 

16 

-32 768-32 767 

long 

long int 
signed long 
signed long int 

32 

-2 147 483 648〜 

2 147 483 647 

unsigned char 

一 

8 


unsigned 

unsigned int 

16 


unsigned short 

unsigned short int 

16 


unsigned long 

unsigned long int 

32 

0-4 294 967 295 

float 


32 

±3.4 E 38(7 자리) 

double 


64 

±1.7 E 308(16 자리) 

long double 


80 

+ 1.2 E 4 932(19 자리) 


(이것은 번역프로그람에 따라 달라질수 있다.) 

③ 문자형 

C 프로그람에서 취급할수 있는 문자들로서는 언어의 기본기호에 해당한 문자들이 
포함된 다. 를뉴터 내 부에 서 는 문자도 역 시 0과 1의 비 트렬 로 표시 된 다. 현재 사용되 고 
있는 아스키코드체 계 에서 는 한 문자당 8 bit 즉 lbyte 를 할당하고있 다. 

E 1 I 2： 문자 a 는 0 x 61 
문자 A 는 0 x 41 

여 기서 보여주는바와 같이 아스키코드체 계 에서 매 개 문자는 lbyte 의 서 로 다른 
아스키 코드값을 가지 며 0 x 00 - OxFF 까지 최 대 256가지 의 문자를 표시 할수 있 다. 이 
로부터 문자형은 lbyte 의 크기를 가지며 형이름 char 로 표시된다. 

E1I 3 ： char a, b, c ； 

a = ’ X ’ ； /* 0 x 58 */ 

b = ’ Y ’ ； /* 0 x 59 */ 

c = ’ Z ’ ; /* 0 x 5 A */ 

여 기서 변수 a , b , c 는 형이름 char 에 의하여 문자형변수로 되며 매 변수들은 
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lbyte 의 아스키코드값을 가질 수 있 다. 따라서 변수 a 에 는 문자 표의 아스키코드값 
0 x 58 이 기 억되며 마찬가지 로 변수 b 와 c 에도 각각 문자 Y 와 문자 고의 아스키코드값 
인 0 x 59， 0 x 5 A 가 기억된다. 

문자형자료의 특징 으로부터 문자형자료를 lbyte 의 옹근수형자료로 취 급하는것 도 
가능하다. 례를 들어 프로그람 

mainO { 
char cl , c 2； 

printf ( f '% c % c \ n M , cl , c 2) ； 
printf ( f '% d % d \ n M , cl , c 2) ； 

} 

을 실행시키면 다음의 결과가 얻어 진다. 


a b 
97 98 

아스키코드로 0~127개 의 문자를 사용하면 바이 트에 서 제 일 웃비 트가 0이 므로 %d 
를 리용하여 출력할 때 정의 옹근수가 출력된다. 만일 아스키코드로 128-255 개의 문 
자를 사용하면 바이 트의 제 일 웃비 트가 1이 므로로 출력할 때 부의 옹근수가 출력 
된다. 례를 들어 다음의 코드(프로그람토막) 


char c = 130； 
printUd ’’， c ) ； 

을 실행시키면 결과는 -126 이 얻어 진다. 

만일 부호처 리 를 진행하지 않으려면 char 형의 변수를 unsigned char 로 정의하 
여 야 한다. 이 때 char 형변수의 값범 위 는 0〜255이 다. 

signed char 와 unsigned char 의 의미와 사용법은 signed int , unsigned int 
와 같으며 다만 한개 바이 트를 차지 한다는데 서 만 차이난다. 

3) 사용^ᅡ정의형 

체계 가 정의 한 표준자료형 을 가지고서는 프로그람을 원만히 작성 할수 없다. 

례 로 도서 목록프로그람을 작성하려 고 할 때 해 당 책 을 특징 짓 는 지 표로서 책 의 제 
목，페지수，출판년도，출판사，집필자이름 등을 선정한다면 이러한 자료를 보관하기 
위한 표준자료형 은 C 언어 에 주어 져 있지 않다. 

C 언어는 체계가 정의한 표준자료형외에 사용자에 의해서 자료형을 창조할수 있도 
륵 정 의하는 방법 을 제 공하고있 다. 

사용자정의 형이 란 체계 에 의 해서 가 아니 라 사용자에 의하여 정의되는 자료형 을 말 
한다. 
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사용자정의형에는 구조체형과 공용체형，렬거형이 있다. 

사용자정의형 자료형 에 대 하여서는 뒤 에서 구체 적 으로 보기 로 한다. 


4) 형변환 

- 자동형변환 

일 반적 으로 C 언어 는 자료의 형 을 제 한하지 않는 프로그람작성언어이 므로 하나의 
식에 여 러가지 자료형을 가진 변수들을 섞어쓸수 있다. 즉 혼합연산이 가능해진다. 

C 언어는 혼합연산이 진행될 때 자동적으로 높은 자료형으로 변환해준다. 

자료형 은 기 억기의 크기 를 결정하므로 작은 크기 로 할당된 기 억기의 내 용을 그보 
다 큰 기억공간에 보관할수 있지만 자기보다 작은 기억공간에는 보관할수 없다. 왜냐 
하면 자료를 잃어 버 리 기때 문이 다. 일상생 활에 서 10 L 짜리 바께쓰에 5 L 의 물을 담을수 
있지 만 5 L 짜리 바께쓰에 10 L 의 물을 담을수 없는 원리 와 같다. 그러 므로 낮은 자료 
형에서 높은 자료형으로의 변환은 자동적으로 진행된다. 

례 4： ^include < stdio . h > 
mainO 
{ 

int a , b ； 
double c , d ； 
unsigned char e ； 
a = 500; 
b = 7; 
e = 100； 
c = a + e ; 
d = 2 * c ; 

printf (“ % d % d % f % f \ n ”， a , b , c , d ) ； 

} 

이 프로그람을 실행하면 500, 7, 600.0, 1200.0 이 라는 값이 출력된다. 

명령문 c = a + e ; 에서 변수 c 는 double 형， a 는 int 형， e 는 char 형이므로 자동 
적으로 더 높은 자료형인 double 형의 연산결과로 현시된다. 

- 강제형변환 

다음의 코드를 고찰하자. 
double y ； 
y = 1/3; 

이 명 령 문을 실행 한 결과 y 에는 0이 값주기된다. 그것은 연산이 옹근수 1과 옹근 
수 3의 나누기이 므로 옹근수상인 0이 모에 값주기되 기 때 문이 다. 

그러나 y = 1.0/3; 으로 쓰면 y 에는 0.33 이라는 값이 값주기된다. 왜냐하면 1.0 
이 라는 실수의 나누기 를 진행하였기때 문이 다. 

이 와 같은 현상을 없애 기 위하여 C 언어 는 강제 형변환기 능을 제 공한다. 

자료앞에 변환하려 는 형예 약어 를 붙여 서 요구하는 형 으로 변환하는것 을 강제 S 변환 
이 라고 한다. 
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례 5： y = ( float ) 1/3； 

이 외 에도 형변환함수들을 리용하여 형변환을 진행할수 있다. 

앞에서 배운 지식에 기초하여 두 수 3과 4의 평균값을 계산하는 프로그람을 다음 
과 같이 작성할수 있 다. 



이 프로그람에서 float a ， b ， c ; 명령문은 변수 a , b , c 의 자료형이 실수형인 float 
형 이 라는것 을 선언한것 이 다. 

실 행단주 」_를 찰칵하면 조작탁창문에 결과가 다음과 같이 현시 된다. 
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련습문제 

1. 다음의 변수들의 이름이 옳은가 틀리는가? 그 근거를 밝히여라. 


ᄀ) _1234 

니 

&xyz 

도) abc 

근) struct 

n ) 

18 cb 

ᄇ) %y 

다음의 수들을 

기 억 하려 면 

몇 byte 이 면 

충분하겠는가? 

ᄀ) 103 

ᄂ) -129 


37 855 

근) -65 500 

n ) -32 

760 ᄇ) 

+255 


3. 다음의 자료들을 관리 하기 위한 자료형 을 선택하여 라. 


ᄀ) 15 

ᄂ) -358 


8.57 

근) 

6.5 X 10" 8 

n ) 756 398 

ᄇ) +135 687 

入) 

“ korea ” 

ᄋ) 

“123，， 



틈 # 터 상져 


사람의 노[수와 콤퓨터의 기억능력 



정도의 기억용량이 필 


1초동안에 실행되는 연산회수와 기억용량이 
이 비률은 콤퓨터 를 만가동시킬 목적 에 서 설 


콤퓨터가 사람의 뇌수와 같은 능력을 가지려면 어 
요하겠는가? 

연구자료에 의 하면 를뉴터 에 서 
수자상으로 거 의 일 치하군 하였 는데 
정된것들이였다. 

만약 이 와 같은 비 률을 념 두에 둔다면 1초동안에 10조회 의 연산을 진행 하 
는것 으로 보는 사람의 뇌 수와 맞먹 는 규모의 콤퓨터 에서는 10조단어 의 기 억 장치 
다시말하여 약 1 000조 bit 정도의 기억용량이 필요하게 된다. 그것은 콤퓨터에서 
는 한 단어가 16 bit 로부터 64 bit 사이에 놓이는것이 보통이기때문이다. 

연구자들이 연구한데 의하면 현재 첨 단수준의 과학연구사업 들에 사용되 고있 
는 콤퓨터의 능력이 대체로 곤충의 신경계통정도의 수준이라는것을 알수 있었다 
고 한다. 

콤퓨터의 끊임없는 수준향상으로 콤퓨터능력이 20년마다 1 000배의 속도로 
증가하고있으며 이 속도로 나간다면 인간의 뇌수와 대등한 수준의 콤퓨터에 요구되 
는 초당 10조연 산이라는 처리속도는 2030년경까지는 개인용를 뉴 터에서 도 
가능해 지 는것 으로 된다. 


38 






























제 3 걸. 年 4의 크기비교 


이 절에서는 두 수의 크기를 비교하는 례를 동하여 C 언어에서 연산자의 개념과 
분류 그리고 산수，비교，값주기연산자에 대하여 학습하기로 한다. 

두 수 a , b 의 크기 를 비 교하여 그 결 과를 출력하는 프로그람을 작성 하자. 알고리 
듬은 다음과 같이 작성할수 있 다. 

① 시작 

② a 에 값주기 

③ b 에 값주기 

④ a 와 b 의 크기비 교 

⑤ 출력 

⑥ 끝 

C 언어에는 두 수의 합과 차의 계산，크기비교 등을 할수 있는 여 러가지 연산자들이 있다. 

1. 연산자의 개념과 분류 

상수，변수，함수와 연산자를 결합하여 표현한 값을 식이 라고 한다. 

콤퓨터로 문제를 푼다고 할 때 그것은 각이한 형태의 식을 계산하여 결과를 얻어나가 
는 과정 이 다. 이와 같이 어떤 식 을 계산하여 결과를 얻 어 내는 과정 을 연산이라고 한다. 
연산에는 산수연산，문자렬연산，비교연산，론리연산，비트연산，주소연산 등이 있다. 
연산에 참가하는 기호를 연산자라고 하며 연산의 대상을 연산수라고 한다. 

연산수가 1개인가 2개인가에 따라 단항연산자，2항연산자，3항연산자라고 한다. 
례: A = B + C 

여 기서 A , B , C 는 연산수이 고 =와 +는 연산자이다. 

C 언어에는 연산의 종류에 따라 수많은 연산자들이 있다. 이것이 C 언어의 중요한 
우점 이 다. 

C 언어 가 제 공하는 연산자들을 합리 적 으로 리용하면 프로그람이 간소화되 며 따라 
서 프로그람의 번역속도나 실행속도가 훨씬 빨라전다. 

2. 산수연산자 

산수연산은 산수식 을 계 산하여 수값형 태 의 자료를 얻 는 연산이 다. 

산수식은 두개 혹은 그이상의 연산수들을 산수연산자와 괄호로 련결하여놓은것을 말한다. 
산수연산을 표현하는 연산자를 산수연산자라고 한다. 
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c 언어가 제공하는 산수연산자에는 수학에서와 같이 더하기 (+)，덜기(-)，곱하기 
(*)，나누기(八 를 진행하는 4칙연산자외 에 나머 지연산을 진행하는 나머 지연산자(%) 가 
있 다. 


+ 

더 하기 

A + B 

A 와 묘의 합 

一 

덜 기 

A - B 

A 와 묘의 차 

* 

곱하기 

A * B 

A 와 묘의 적 

/ 

나누기 

A / B 

A 를 묘로 나눈 상 

% 

나머 지 

A % B 

A 를 묘로 나눈 나머 지 


연산을 진행할 때 괄호 ( ) 를 리용하여 우선권을 보장할수 있다. 

산수연산자들은 모두 2개의 연산수를 가지는 2항연산자들이다. 

Ell 1 ： y * (x + 3) 
a + b 
-x + y 
y mod 6 

어 떤 변수에 하나를 더 하거 나 더 는 득별 한 단항연산자로서 증가연산자 ( ++ ) 와 감소 
연산자 (--) 가 있다. 

일반형식: 


E 1 I 2： a ++； /* a = a+l 

a — ； /* a = a_l 

증가，감소연산자는 연산수의 앞에 놓일수도 있고 연산수의 뒤에 놓일수도 있다. 

이 경우 식평가에서 차이가 있다. 

례 3： ++ a : a = a + l 을 진행한 다음 그 값을 식 에 적 용한다. 
a ++： a 의 값을 식 에 적 용한 다음 a = a + l 을 진행한다. 

례 4： int a = 1， b , c ； 

b = a ++； /* b=l */ 

c = ++ a ； /* c =3 */ 

printf (’’ b =% d \ n ’’， b ) ； 
printf ( f ' c =% d \ n M , c ) ； 


++ : 증가연산자 
— : 감소연산자 

*/ 

*/ 
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3. 비교연산자 


우리 는 수학에 서 x + y <1.5 라든가 x ^ -10.5 와 같은 같기식，안같기식 들에 대 
하여 배운다. 

비 교연산은 같기식，안같기식 에 대 응하는 개 념 으로서 자료의 크기 를 비 교하는 연 
산이다. 비교연산을 표현하는 연산자를 비교연산자라고 한다. 

C 언어가 제공하는 비교연산자는 다음과 같다. 


의 미 

수 학 

C 언어 

실 례 

작기 

< 

< 

A<B 

작거나 같기 

< 

<= 

A<=B 

크기 

> 

> 

A〉B 

같거 나 크기 

> 

>= 

A〉=B 

같기 

= 

= = 

A==B 

같지 않기 

半 

! = 

A!=B 


비 교연산자들은 모두 2항연산자들이 다. 

비 교연산에 서 는 다음과 같은것 을 주의 하여 야 한다. 

① 비교연산수들은 반드시 같은 형으로 되여야 한다. 

② 비 교연산을 할 때 수값은 수의 크기 에 따라，문자렬 은 문자의 아스키코드값에 
따라 크기 를 결 정한다. 

③ 비 교연산의 결과는 1과 0만을 가전다. 즉 참 ( true ) 인 경 우에 는 1，거 짓 
( false ) 인 경 우에 는 0을 준다. 

례 1: 5 < 3 국 0 ( false ) 

“ bad ” > “ back ” 국 1 ( true ) 
a > b 국 a 가 b 보다 큰가? 

x == y + 1 국 표가 y +1 과 같은가? 
a * b 〉 c 국 a * b 가 c 보다 큰가? 


E 1 I 2： 비 교연산자를 리용하는 프로그람 

^ include 〈 stdio . h 〉 
void main ( void ) 

{ 

int 3, = 1 ， b ~2; 

printf ( f '% d<%d ? M \ n ’’， a ， b ， a < b ); 
printf (”% d<=%d ? M \ n ’’， a , b , a<=W ； 
prin 에 d〉%d ? M \ n ’’， a ， b ， a 〉 b ); 
printf (”% d〉=%d ? a , b , a >= b ) ； 



































4. 값주기연산자 


값주기연산자는 어 떤 변수에 값을 넣어 주는 연산자이다. 

기 본값주기연산자는 =이 다. 

=는 오른변의 값을 왼변에 넣 기 하는 기 본값주기연산자이다. 
일반형식: 


V = e ; 

V : 변수이름 ， e : 식，= : 값주기 연산자 


례 1： a =3; /* 변수 a 에 3을 값주기한다. */ 

c = x * y ; /* 변수 c 에 표와 보를 곱한 값을 값주기한다. */ 

값주기연산자는 산수연산자(+，_，*， /), 비 트연산자(&，|， ' <<,〉〉) 와 조합하 
여 식 을 간단하게 하면서 도 여 러 가지 연산을 진행 하게 한다. 

여기서는 산수연산자와의 조합만을 보기로 한다. 


의미 

기호 

식 

곱하기 

* = 

a *= b : 

값주기 


a = a*b 

나누기 

/= 

a /= b : 

값주기 

a = a/b 

나머 지 


a %= b : 

값주기 

a = a%b 

더 하기 

_ 

a += b : 

값주기 

\ —— 

a = a+b 

덜기 


a _= b : 

값주기 


a = a_b 


일 반적 으로 다른 프로그람언어 들에서 는 값주기연산을 x = x + a 로 쓰지 만 C 언어 에서 
는 간단히 표+=크로 쓸수 있다. 

이와 같이 두개의 연산자를 결합하여 사용함으로써 프로그람코드의 표현을 줄일수 있다. 

E 1 I 2： A *=( B = C + D ); 는 다음과 같은 연산을 묶은것과 같다. 

f B = C + D ; 

1 A = A * B ; 

이 례에서 본것처 럼 하나의 명 령문에 여 러 값주기연산자가 있어도 되지만 그 연산 
순서를 ( ) 로 정확하게 표현해주어 야 한다. 
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련습문제 


다음 식 에서 연산순서 를 밝히 고 C 언어 에서 제 공하는 연산자로 표시 하여 라. 


1) 0.2 a - |b + 등 + b | +a 

2) 3 a - {2 b + [4 a - ( _ b - 3 a ) + b + (a + 2 b - 3 c )]} 


3) 


5) 


x 2 -y 2 


2 


4) 


x 


x 


2 


X 


3 


X 


2 


X 


2 


X 


2 


a 


2 


b 2 


C 


2 


6 ) 


xy 

yb 


2! 3! 

z - b 


2 . 다음 식에서 연산순서를 밝히고 연산결과를 쓰시오. 


1) 10 + 100/2%4*3_6/3*2 

2) 30 _ (5 * 5 * 5) % 10 / 5 + 7 / 2 



소년시절 가우스의 한가지 일화 

프로그람에서 절차가 긴 렬로 서술되는 처리는 경우에 따라 간단한 조작으 
로 같은 결과가 나오도록 수학적으로 변환할수 있다. 

유명한 수학자 가우스는 소년시절에 학교에서 뛰여난 학생이였다고 한다. 

한번은 교원이 재 미절반으로 학생들을 향하여 1부터 100까지의 옹근수를 
전부 더 하라는 문제를 냈다. 학생들은 수자를 하나하나 더 해나가는데 여념이 없 
었으므로 긴 계산시간이 필요되였지만 가우스만은 순식간에 정확한 해답을 냈 
다. 그는 100까지의 수자를 50개의 쌍 즉 1+100，2+99，3+98，…로 가르고 모 
든 쌍이 1()1 이 라는것 에 주목하였 다. 1()1 을 50배 하면 5050이 며 이 방법 이면 
그 많은 더하기계산을 하지 않고도 해답을 구할수 있었다. 이러한 계산의 고속 
화의 수법 은 복잡한 콤퓨터처 리 에서도 중요하게 나선다. 이 른바 〈〈 최 적 화를파일 
러》는 고속화를 위 한 변환용목록을 가지 고있 으며 경 우에 따라 매 우 근본적 인 변 
화에 의하여 번역도중에 프로그람을 능률적 으로 만든다. 여 기서 열쇠 로 되 는것 
은 가우스가 한것 처 럼 계 산의 순서 와 자료의 표현을 전면적 으로 재 구성하는것 이 
다. 우에 서 언급한 소년시 절 가우스에 대 한 일 화는 후에 알려 진데 의 하면 사실 
이 외곡된것 이 라고 한다. 실제 로 교원이 제시한 문제는 우에서 언급한것보다 훨 
씬 더 힘든 문제였는바 81297+81495+81693+ … +100899를 구하는것이 였다고 
한다. 이 문제를 소년시절 가우스가 우의 방법으로 순식간에 암산하였다는것이다. 
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제 4 점. 상각비계산 


이 절에서는 삼각비를 계산하는 문제를 동하여 전처리문과 입줄력함수 그리고 수 
값처 리표준함수들에 대하여 보기로 한다. 

각 표의 값을 입력하면 그에 대한 시누스，코시누스，탕겐스값을 구하는 프로그람 
을 작성하자. 알고리듬은 다음과 같이 작성 할수 있다. 

① 시작 

② 각 표의 값을 입 력 

③ a—-sin(x) 

④ b—-cos(x) 

⑤ c^tan(x) 

⑥ a, b, c 출력 

⑦ 끝 

C 언어에는 삼각함수값을 계산하는 함수가 표준적으로 제공되여있다. 

1. 전처리문 


1) 전처리문에 대한 개념 

앞의 례 들에 서 는 항상 프로그람의 본체 를 작성 하기 앞서 #include <stdio. h> 라는 
명 령 문을 써 넣 었다. 이것은 stdio.h 라는 파일을 삽입하라는 뜻이 다. 

전처리문 (preprocessor) 이 란 번역 프로그람이 프로그람을 번 역 하기 에 앞서 진행 하 
여 야 할 처 리 내 용을 지 시 하는 명 령 문이 다. 

전처 리문을 리용하면 지정된 파일의 삽입 이 나 문자렬교체 (치 환) 등의 조작들을 쉽 
게 할수 있다. 이것은 C 언어에서 제공하는 가장 편리한 기능의 하나이다. 

C 언어의 명령문들은 반두점 (;) 으로 구분하면서 한 행에 여러개의 명령문들을 쓸수 있다. 
그러나 전처리문은 한 행에 한개의 명령문만을 놓을수 있다. 만일 전처리문이 한 행 
을 벗어날 때에는 행의 끝에 빗선 \을 붙이고 다음행 에 계속 쓰면 된다. 

전처리문에는 파일삽입문，문자렬치환문，조건부번역문 등이 있다. 

여 기 에서 는 파일삽입문과 문자렬치 환문만을 보기 로 한다. 

2) 파일삽입을 위한 전처리문 

파일의 삽입 은 전처 리문예약어 include (포함하다)를 리용한다. 

일반형식: - 

^include <파일 이름〉 

^include “파일 이름’’ 


<파일 이 름〉으로 지정하면 미 리 번역프로그람에 게 지시되 여있는 등록부로부터 파 
일 을 검 색한다. 번 역프로그람에는 서 고파일 이 나 머 리 부파일 의 등록부위치(경 로) 가 등 
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륵되 여있다. 그러므로 C 언어 에서 제 공하는 표준함수를 리용할 때 에는 <파일 이름〉형 식 
으로 파일의 삽입을 진행한다. 

“파일이름”형식의 파일삽입은 번역프로그람에 등록되여있지 않는 등록부로부터 파 
일의 검색을 진행하는 경우이다. 

례 1： ^include < stdio . h > 

^include < math . h > 

^include “ d :\ usr \ include \ to . h ” 

파일의 삽입 을 위한 전처 리문을 프로그람에 써 놓으면 번역프로그람은 번역 하기 전 
에 먼저 그 위치에 해당한 파일을 삽입하고 그다음에야 원천파일과 함께 번역한다. 


stdio. h 
에 있는 
내용이 
삽입 


〉 


_ 6止6우기 

\ 

| 파일의 삽입은 왜 진행하는가? | 

I C 언어가 제공하는 모든 표준함수들은 확장자가 lib 인 서고파일에 들어있다. | 
| 이 서고파일에 있는 함수들의 선언은 머리부파일 *. h 에 있으므로 프로그람작성시 | 
| C 언어가 제공하는 표준함수를 리용하려면 함수선언부가 있는 머리부파일을 삽입하 | 
| 여야 한다. | 

| 파일 의 삽입 은 또한 프로그람의 공동리용을 위하여 필 요하다. 어 떤 기 능을 수 | 

I I 

| 행하는 프로그람이 존재할 때 그것을 다시 작성하지 않고 반복리용한다면 프로그 | 
| 람개 발속도를 높일수 있 다. 이 와 같은것 을 프로그람의 공동리용이 라고 말한다. | 
| 례로 두 학생이 n ! 과 관련한 문제를 푼다고 할 때 두 학생이 각기 n ! 을 작성 | 
| 할 필 요가 없 이 한 학생 이 작성한것 을 서 고파일 로 만들어 놓고 공동으로 리용한다 | 

! 면 프로그람의 리용률을 높일수 있을것 이 다. I 

j ! 



^include < stdio . h > 
mainO 
{ 

char file [64] ； 

• • • ••• • • • 

if ( NULL ==( fp (… ))) 

• • • • • • • • • 

} 


#define NULL 0 
#define EOF (-1) 


mainO 

{ 

char file [64] ； 

• • • • • • • • • 

if ( NULL ==( fp (… ))) 

• • • ••• • • • 

} 
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3) 문자렬치환을위한 전처리문 

문자렬치 환은 어 떤 수값이 나 문자렬 과 같은 상수들이나 식 을 알기 쉬 운 문자렬 로 
바꾸어 프로그람을 쉽 게 해 석할수 있게 하며 프로그람에 서 여 러 번 쓰이 는 상수들을 정 
의하는데 서 매 우 편 리하다. 

문자렬 치 환은 전처 리 문예 약어 define (정 의 하다)을 리 용한다. 

일반형식: _ 

#define 식 별 자 상수 
#define 식 별자 식 


문자렬치 환전처 리문이 있으면 번역프로그람은 프로그람본체 에 서 나오는 모든 식 별 
자들을 상수나 식으로 바꾸어준다. 


#define SIZE 10 


mainO 

mainO 


{ 

{ 


char file [10] ； 

char file [ SIZE ] ； 


• • • • • • ••• 

• • • • • • • • • 


for ( i =0; i 〈10; i ++) 

for ( i =0; i < SIZE ； i ++) 

= 三〉 

• • • • • • • • • 

• • • • • • • • • 

} 

} 


E 1 I 2： #define LENGTH 100 

#define MAX ( A , B ) ((( A ) 〉= ( B ))?( A ) ： ( B )) 

#define VOL ( R ) ( R * R * R ) 

문자렬 치 환시 파라메 터 를 가지 는 문자렬 은 0 로서 막는다. (파라메 터 에 대 한 개 념 
은 뒤에서 본다.) 

# undef 전처 리문은 # define 문으로 지정 한 치환을 중지 하게 한다. 즉 # undef 전처 
리 문 이 나 타 난 시점 에 서부터는 치환 하지 않는다. 

E 1 I 3： #define TRUE -1 /* TRUE 를 -1 로 치환 */ 

#define FALSE TRUE /* FALSE 를 TRUE 로 치환한 결과 _1로 인식된다.*/ 
#define BOOL int /* BOOL 형 을 int 형 으로 치환 */ 

int a ； 

• • • • • • ••• 

#undef BOOL 

#define BOOL char /* BOOL 을 char 로 다시 치 환 */ 

ai 4 ： ooc 부터 ioooc 까지 iooc 마다 셀씨우스온도 ( 。 c) 로부터 화렌하이트온도 (。: 이로 
변환하는 온도변환표를 작성하는 프로그람은 다음과 같다. 

^include < stdio . h > 

#define LOWER 0 
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#define UPPER 100 
#define STEP 10 
mainO 
{ 

int c ； 

for ( c = LOWER ; c <= UPPER ; c += STEP ) 
printf (“% d % d \ n ”， c , c *9/5+32) ； 

} 

2. 표준함수 

표준함수는 C 언어프로그람개 발자들에 의하여 미 리 정의된 전용의(특정한) 기 능을 
수행하는 함수로서 C 언어프로그람개 발환경 에 들어있는것 이 아니 라 서 고파일 로 준비되 
여있다. 표준함수는 서고에 준비되여 있으므로 필요한 표준함수를 리용하려면 전처리문 
을 리용하여 서고파일의 위치를 알려주어야 한다. 

1 ) 입출력표준함수 

(1) 형식화된 입출력함수 

- 형 식 화된 자료출력 함수 ( printf : print formatted ) 

일반형식: _ 

printf (“출력 형 식 ’’， 식 1， 식 2，…， 식 n ) 


기능: 출력 형 식 지 정 에 의하여 문자나 문자렬，수값을 비 롯한 계 산결과를 출력한 
다. 출력형 식은 다음과 같다. 


%H [〈마당의 크기〉] <자료형 식〉[\조종기히 


자료형식에는 다음의 기호가 리용된다. 



부호있는 10 진옹근수로 출력 


부호 없는 10진옹근수로 출력 

%o 

8진수로 출력 

宅 X 

16진수로 출력 


고정소수점형식의 출력 

%e 

류동소수점 °J 식 의 줄력 


M 와가운데서 보다 짧은쪽으로 출력 

%c 

문자로 출력 


문자렬로 출력 


조종기호는 출력 조종을 진행할뿐 화면에 는 표시 되 지 않는다. 
조종기호는 다음과 같다. 
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\n 

행 바꾸기 

\” 

’’를 표시 

\t 

수평 으로 8 문자 뛰 여넘기 

V 

’를 표시 

\f 

페 지 바꾸기 

\\ 

\를 표시 

\r 

되돌아가기 

\ddd 

3자리 8진수표시(아스키코드) 

\b 

한문자 앞으로 이동 

\xhh 

16진수표시 (아스키 코드) 


마당크기: 오른쪽，왼쪽을 기준으로 자료를 출력하기 위해서는 마당크기를 지정 
할수 있 다. 자료의 출력 을 진행할 때 출력 형 식 을 % d , % e , %구를 지 정하면 유효길 이만큼 
출력하기때문에 출력되는 값에 따라 표시되는 위치가 변한다. 이것을 피하기 위하여 
마당크기 를 지 정한다. 

《의 오른쪽에 -를 붙이면 그에 대응하는 값은 마당의 왼쪽끝에 맞추어 출력된다. 
생 략하면 오른쪽을 기준으로 표시된다. 마당의 크기보다 유효길이가 짧으면 그만큼 공 
백이 놓인다. 

소수점 이 있는 경 우에 는 표시한 마당의 전체 길 이 와 소수점아래 에 표시 될 자리 수를 
지 정할수 있 다. 즉 마당의 크기 를 다음과 같이 지 정한다. 

<마당전체의 길 이〉.<소수점아래의 길 이〉 

표시할 자료가 문자렬이 면 문자렬 의 일부만을 표시할수 있 다. 

〈마당전체 의 길 이〉.<표시 할 문자수〉 

결과 지정된 문자 렬의 왼쪽에서부터 지정된 문자 개수만큼 표시된다. 
printf 함수는 머 리 부파일 stdio.h 에 선언되 여있 다. 

이 함수를 리용하자면 다음과 같은 명 령 문을 프로그람의 선두에 삽입하여 야 한다. 
^include < stdio . h > 

ai i ： 다음의 프로그람은 화면에 어떤 형식으로 자료를 출력하는가? 

^include < stdio . h > 
void main ( void ) 

{ 

printf ( M 111111111122222222223\ n M ) ； 

printf (’’12345678901234567890123456789( 八 n ”); 

printf ( M - \ n M ) ； 

printf (，，%-10 d %10 d \ n M , 12345,12345) ； 

printf (，，%10 s %-10 s \ n M , " ABCDEFGHI ", " abcdefghi ") ； 

printf (，，%-15 e %10 e \ n M , 123. 456, 0.123 e -3) ； 

printf (” %_15. 5 s %10.5 s \ n ”, 

" ABCDEFGHIJKLMNO ", " abcdefghijkl ") ； 
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결과: 


111111111122222222223 

123456789012345678901234567890 


12345 12345 

ABCDEFGHI abcdefghi 
1.23450 e +002 1.230000 e -004 

ABCDE abcde 

Ell 2： 화면에 C programming Language 라고 표시 하는 프로그람은 다음과 같다. 

^include < stdio . h > 
mainO 
{ 

printf ( 44 C programming Language \ n ”); 

} 

ai 3 ： 출력결과가 다음과 같은 프로그람을 작성하면 아래와 같다. 

ABCD 

EFG 

HIJKL MNO 

PQR 

STUV WXY 

^include < stdio . h > 
mainO 
{ 

printf (“ ABCD \ n ”) ； 

printf (“ EFG \ n ”) ； 

printf (“ HIJKL MNO \ n ”); 

printf (“ PQR \ n ”) ； 

printf (“STUV WXY \ n ”); 

} 

- 형 식화된 자료입 력함수 
일반형식: 


scanf (“입 력 형 식”，변수1，변수2，…，변수 n ) 


기능: 입력형식에 기초하여 건반으로부터 자료를 입력하여 지정된 변수들에 보관 
한다. 입력형식은 printf 함수와 같다. 
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지정된 변수에로 건반자료가 입력되므로 그 변수가 차지하고있는 주소가 요구된다. 
그러므로 변수목록에 들어가는 매 변수(지적자변수가 아닐 때에만)이름의 앞에 주소연 
산자 &를 붙여 주어 주소를 지 정 한다. 

scanf 함수에 서는 인쇄 조종기호 님을 사용하지 않는다. 
scanf 함수도 머 리 부파일 stdio . h 에 선언되 여있 다. 

알아두기 __ 

scanf 함수를 사용하는데서 주의할 점 

① scanf () 함수가 형식에 기초한 입력으로 생각하고 입력형식화안에 문자렬 
을 쓸수 없다. 가령 입력하기 전에 문자렬통보문을 현시할것을 생각하고 printf 
함수처 럼 scanf ( “Input number : % d ” ， & n ) ； 라고 쓰면 오유가 발생 한다. 문 
자렬 출력 은 printf 0 함수를 리용하여 야 한다. 

② scanf () 함수가 실 행 되 여 자료를 입 력 해 야 할 때 아무것 도 입 력 하지 않고 
Enter 건을 누르면 변수에 아무것 도 들어가지 않는다. 

③ scanfO 함수에 의하여 하나의 변수에 수값을 입력할 때 수자들사이에 공 
백 이 있 으면 공백앞까지 의 자료만 변수에 들어간다. 례 로 13 45라고 입 력하면 
변수에는 13만 입 력 된다. 



E 1 I 4： 건반에 의하여 3자리 의 10진수를 읽어서 그것 을 변수 표에 넣 고 다시 현시하 
는 프로그람 


1 : ^ include 〈 stdio . h 〉 

2 ： mainO 
3： { 

4: int x ； 

5: scanf (“%3 d ”，& x ) ； 

6 : printf (“ %3 d \ n ’’， x ) ； 

7： } 



1 행 에 서 술된 명 령 문은 프로그람에 서 리용되 는 표준입 출력함수들의 선언을 위한 
머 리부파일삽입 을 진행한다. 

4행 에서 는 문제 의 요구에 따라 변수 표를 선언한다. 

5행 에서는 10진수 3자리를 읽기 위하여 입 력형 식지정 에서 마당크기를 3 d 로 지정 
하였다. 

6 행 에서는 역시 3자리 로 출력형 식 을 진행하여 출력한다. 
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ai 6： 여러가지 자료형을 리용한 례 

^include <stdio. h> 
mainO 
{ 

long a ； 

unsigned int b ； 
char c ； 

120000 ; 
b=0x3FFF ； 
c=ol5; 

printf (“value a is %d\n ”， 
printf(“value b is %x\n ”， 
printf (“value c is %o\n ”， 


해 설 


b=0x3FFF; 명령문에서 Ox 는 뒤의 수자가 16 진수임을 나타내며 c=ol5; 에서 o 
는 뒤의 수자가 8진수임을 나타낸다. 

(2) 문자，문자렬입출력함수 

- 한 문자 입력 

한 문자의 입력 에는 %c 의 지정 으로 scanfO 를 사용할수도 있지만 보다는 getcharO 
함수를 많이 사용한다. 


E1I 5: 두 수 a 와 b 를 입 력하여 그의 적，상，합，차，나머 지 를 구하고 화면 에 줄력 
하는 프로그람 

^include <stdio. h> 
mainO 
{ 

int a,b ； 

scanf (“ %dgd’’ ， &a, &b) ； 
printf (“% d x %d=%d\n ’’， a, b, a*b) ； 
printf (“ %d + %d=gd\n ” ， a, b, a/b) ； 
printf (“%d + %d=%d\n” ， a, b, a+b) ； 
printf (“ %d — %d=%d\n” ， a, b, a_b) ； 
printf (“%dE%d=%d\n” ， a ， b ， a%b) ； 


a)bc) 
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레 7 ： char c ； 

scanf ("%c=" ， &c) ； 
printf ( M c=%c M , c) ； 
c=getchar(); 
printf ( M c=%c M , c) ； 

getcharO 함수는 눌리 운 건에 해 당한 아스키 코드값을 돌려 준다 . 

- 한 문자 출력 

getcharO 함수의 경우와 마찬가지 로 한 문자 출력도 以:를 지정한 printfO 함수보 
다 putcharO 함수를 많이 사용한다 . 

례 8 ： char c ； 

c=getchar() ; 
printf (” %c”, c) ； 
putchar(c) ； 

- 문자렬의 입력과 출력 

문자렬의 입 력과 출력 에는 gets 0 와 puts 0 를 사용한다 . 

E1I 9 ： 문자렬 을 입 력 하고 그것 을 다시 출력하는 프로그람 

^include <stdio. h> 
void main (void) 

{ 

char buf [50] ； 
gets(buf) ； 
puts (buf) ； 

} 

례에서 보는바와 같이 getsO 는 공백 을 포함한 한개 의 행 을 그대 로 파라메터 로 
넘겨진 buf 에 보관한다 . 

2) 수값처리표준함수 

절대값함수 abs () 를 제외한 수값처 리표준함수들은 머 리부파일 math, h 에 선언되 
여있 다 . 




:〉 
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C 언 어 가 제 공하는 수값처 리표준함수들은 다음과 같다 . 
























함수 

표의 형 

구의 형 

의 미 

비 고 

abs (x) 

int 


절대값계산 


exp(x) 

double 


e x 계 산 


log(x) 

double 


log e x 

x > 0 

loglO(x) 

double 


logiox 

x > 0 

pow(x,y) 

double 

double 

int 

x y 

x > 0, (x ， y) 뉴 0 

sqrt(x) 

double 


、도 

x ^ 0 

fabs(x) 

double 


실수 표의 절대값 


floor(x) 

double 


표를 넘지 않는 

가장 큰 옹근수 


ceil (x) 

double 


X 보다 작지 않은 
옹근수 


sin(x) 

double 


sinx 


cos(x) 

double 


COSX 


tan (x) 

double 


tanx 


asin(x) 

double 


arcsinx 


acos(x) 

double 


arccosx 


atan(x) 

double 


arctanx 



ai 10 ： 다음의 경우 
y=abs(_3) 
y=exp(2. 5) 
y=log(10. 8) 
y=logl0(10.8) 
y=pow(5 ， 8.5) 
y=sqrt(100. 5) 
y=fabs(_8. 8) 
y=floor(3. 85) 
y=ceil(3. 85) 


y 값은 어떤 값을 가지는가 ? 

: y 에 3 이 값주기된다 . 

: 포에 e 2 ‘ 5 이 값주기된다 . 

: 포에 log e 10.8 이 값주기된다 . 

: y 에 log 10 10.8 이 값주기된다 . 
: 포에 5 8 ’ 5 이 값주기된다 . 

: 포에 "100.5 가 값주기 된다 . 

: 포에 8. 8 이 값주기 된 다 . 

: y 에 3 이 값주기된다 . 

: y°fl 4 가 값주기된다 . 


E1I 11 ： 다음의 프로그람에 서 틀린것 을 지 적하여 라 . 
^include <math. h> 
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^include <stdio. h> 
mainO 
{ 

double a=3. 14 ， b=_3.14 ， c=2. 5, d, e, f, g ； 

int i=2; 

d=pow(a, b) ； 

e=pow(b, c) ； 

g=abs(b )； 


오유는 다음과 같다 . 

8 행 에 서 b 가 부수이 므로 powO 함수를 리용할수 없 다 . 

9 행 에 서 b 가 실 수이 므로 abs() 함수를 리용할수 없 다 . 즉 fabsO 함수 
야 한다 . 


각 표의 값을 입 력하면 그에 대 한 시 누스， 코시 누스， 탕겐스값을 
프로그람은 다음과 같다 . 

^include <stdio. h> 

^include <math. h> 
mainO 
{ 

float x,a,b,c ； 
scanf (“ &x) ； 
a=sin(x) ； 
b=cos(x )； 
c=tan(x) ； 

printf (“sin (x) =%f\n”, a) ； 
printf (“cos (x) =%f\n”, a) ； 
printf (“tan (x) =%f\n”, a) ； 

} 


리 용하여 


구하는 
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련습문제 

1. 다음 프로그람의 실행 결과를 밝히 여라 . 

ᄀ ) ^include <stdio. h> 
mainO 
{ 

int a, b； 
a=1500; 
b=350; 

printf (“ %d/%d=%d.%d\n”, a, b, a/b, a%b) ； 

} 

l) ^include〈stdio.h〉 
mainO 
{ 

int a, b, c, d； 
a=d=3, b=l, c=Q ； 

printf (‘‘ (%d_%d) x (%d_%d)/ (%d+%d)=%d\n’’，a，b，c，d，a，d， 

(a~b) * (c-d) / (a+d)) ； 

} 

ᄃ) ^include〈stdio.h〉 
mainO 
{ 

float a=3. 5, b=2. 9, c=5.1; 
float m； 

m= (a+b+c) / (c-b-a) ； 

printf ( 44 (%f+%f+%f) + a, b, c, c, b, a, m) : 

} 

근 ) ^include <stdio. h> 
mainO 
{ 

int i, j, x, y, z； 

i=7; 

j=5; 

x=i〉j; 

y=i<j; 

z=i==j; 

printf (“i〉j= => %d\n”, x) ； 
printf (“i<j= 국 %d\n”, y) ； 
printf (“i=j= = 今 %d\n”, z) ； 

} 
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ᄆ ) ^include < stdio . h > 
mainO 
{ 

int 3.~5, b ~9; 
printf (“ % d , M \ n ”, ++ a , a ) ； 
printf (‘‘% d , M \ n ’’， a ++, a ) ； 
printf (“% d , % d \ n ’’， 一 b , a ) ； 
printf (“ % d ，% d \ n ’’， b —， a ) ； 

} 

2 . 다음의 기 능을 수행 하는 간단한 프로그람을 작성 하여 라. 

1) X = -4 ， Y = 6 ， Z = 7일 때 (X * Y)/(X + Z ) 를 구하여 라. 

2) 15 + 313 - 214 + (95 / 5) = 의 뒤에 결과를 표시하여라. 

3) 9800/8800의 상과 나머지를 구하여 라. 

4) 329분은 몇 시 간 몇분인가를 구하는 프로그람을 작성하여 라. 

5) 한 변의 길이가 a 인 바른4각형의 면적을 출력하는 프로그람을 작성하여라. 

6) 9 8()1 을 화면의 15번자리 에 표시하는 프로그람을 작성하여 라. 오른쪽에 
표시할 때 왼쪽 11자리 를 0으로 채 우도록 한다. 

7) 3.141 592를 왼쪽을 기 준으로 하여 소수점아래 4자리 까지 표시하여 라. 

8) 16진수 3 A 1 E 를 10진수로 화면 에 표시하여 라. 

9) 8진수 7206을 16진수로 화면에 표시하여 라. 

10) 10진수 8 8()1 을 8진수와 16진수로 화면에 표시하여 라. 

11) 16진수연산 7 AF - 3 BC 를 구하여 16진수，10진수로 화면에 표시하여 라. 

12) 30 X 20의 결 과를 16진수 3자리 로 표시하여 라. 

13) 3각형의 세 변의 길이가 주어졌을 때 면적을 구하여라. 

14) 직3각형의 두 직각변이 주어졌을 때 빗변의 길이를 구하여라. 

15) 반경 r 가 주어졌을 때 원의 면적과 둘레의 길이를 구하여라. 

16) 반경 r 와 높이 h 가 주어졌을 때 원기둥의 겉면적과 체적을 구하여라. 

17) 반경 r 가 주어졌을 때 구의 겉면적과 체적을 구하여라. 

18) 두 밑 변과 높이 가 주어질 때 제형의 면적 을 구하여 라. 

19) 반경 r 인 원에 내 접하는 바른4각형의 면적 을 구하여 라. 

20) 한 변의 길이가 a 인 바른3각형에 내접하는 원의 면적과 둘레의 길이를 
구하여 라. 

21) 웃반경，아래반경，높이 가 주어졌을 때 원뿔대의 체적을 구하여 라. 

22) 직각자 리 표계에서 두 점의 자리 표가 주어졌을 때 두 점 사이의 거리를 
구하여 라. 

23) 직각자리표계에서 세 점의 자리표가 주어졌을 때 3각형의 면적을 구하여라. 

24) 세 수 a , b , c 가 주어졌을 때 합평균，곱평균을 구하여라. 

25) 반경이 rl , r 2, r 3 인 세 원이 서로 접하고있을 때 세 원의 중심점을 정점으로 
하는 3각형의 면적을 구하여라. 

3. 다음 식 을 C 언어 의 식 으로 표시하여 라. 

56 



1) (y - x ，- 1 

2) ( x 2 - y 2 ) x (1 + 2) 

3) x 2 / a 2 + y 2 / b 2 + z 2 / c 2 

4) 1 / a 2 x (b / 2) X n - 1 

5) a - 1 + b / (1 + x 2 ) + |x - 31 / 2 

6) (2 / px ) X sinx 

7) (( e x - e - x ) / 2 ) + (( e x + e - x ) / 2) 2 

8) (x - y)sinx + ( x 2 + y 2 )tanx 

9) | lnx 2 - y | + 7. 3 x - 3 y = 2 x + 3 

10) | a | x | b|cosA 

11) 2 x + b / (1 + x 2 ) + |x - a | / 2 

12) xy / x 2 + y 2 - ln(|x - (1 + x 2 ) / 21) 

13) 1/2 lg((l + sinx ) / (1 - sinx )) 

14) e - l / x ( x - m ) 2 + 5 xsinx 3 

15) ( ln(x - y ) / 2 - sinz ) - 2 

16) lg ( x 2 + 1) / x 2 + 2 arctan(l - a ) / 2 


틈# 터상져 

《진실》과《거짓》의 수학 

현대 의 수자형 콤퓨터 에 서 연산은 2진수 즉 수자 1과 0의 두 값에 의하여 
진행 된다. 이 런 연산에 기 초한 수자형 륭퓨터 는 20세 기 중엽 에 만들어졌지만 이 
것 을 취 급할수 있는 수학적방법 은 이 미 1800년대 중엽 에 영 국의 수학자이 며 론 
리학자인 죠지 불에 의하여 확립되였다. 이 론리연산법을《불대수》라고 한다. 

〈〈불대수》에서는 변수와 명제가 《진실》인가 《거짓》인가의 어느 한 값 
만을 가지 며 연산을 론리적，론리합，론리 부정 등의 연산자에 의하여 론리 적 으 
로 표시한다. 1과 0으로 값을 표시 한다는것 은 전기 회 로스위 치 의 〈〈 투입》과《 차 
단》에 대응시킬수 있기때문에 론리적 이나 론리합 그리고 론리부정 등의 론리연 
산을 그대로 전자회로로 실현할수 있다. 즉 론리연산에 기초한 계산이나 판단을 
장치 에 의 하여 자동화할수 있는셈 이 다. 그리 하여 《불대수》는 몸뉴터 에 쉽 게 응 
용될수 있었다. 그러나 150여년전에 이 연산법을 내놓은 불자신은 생전에 오늘 
과 같은 수자형콤퓨터 의 출현에 의하여 자기 의 연구성 과가 쓰이리 라고는 예 견할 
수 없었을것이다. 
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제 5 점. 학생성적평가 


이 절에서는 학생성적평가프로그람을 작성하는 과정을 통하여 론리연산자와 조건 
명 령문들에 대하여 학습하기로 한다. 

학생의 성적을 입력하여 성적을〈〈최우등》，〈〈우등》，〈〈보통》으로 평가하는 프 
로그람을 작성하여 라. 알고리듬은 다음과 같다. 

< 알고리듬〉 



알고리 듬에서 보는바와 같이 성적 을 입 력하여 먼저 성적 이 4. 5이상인가 아닌가를 
판단하고 성적 이 4. 5보다 작으면 다시 3. 5이상인가 아닌가를 판단하여 결과를 출력하 
여야 하므로 여기에서는 조건이 주어졌을 때 둘중의 하나의 처리를 진행하는 명령문이 
필요하다. 조건식의 판단은〈〈옳다》또는〈〈틀린다》의 두 결과를 가지며 두 결과에 대 
하여 어느 한 처 리를 진행하는데 쓰이는 명 령 문이 바로 조건명 령문이다. 이 절에서는 
론리 연산과 조건판단을 진행 하여 여 러 개 가운데 서 한 처 리 를 진행 하는 명 령 문에 대 하여 
학습하게 된다. 

1. 론리연산자 

우리는 일상적으로 흔히〈〈옳다》，〈〈틀린다》와 같은 말을 많이 한다. 생활에서 흔 
히 쓰는 이러한 말을 표현하는것이 콤퓨터에서 론리형자료이다. 론리형자료에서 《옳 
다》는 잠 ( true ), 《들린다》는 거 짓 ( false ) 으로 표현한다. 연산에는 수값들끼 리 진행하 
는 산수연산도 있지만〈〈참》이나〈〈거짓》과 같은 론리자료로 진행하는 론리연산도 있다. 

모든 연산에는 연산수와 연산자가 있 다. 

론리연산에 서 연산수는 론리 형자료이 다. 론리연산자는 여 러 조건들사이 의 론리 연 
산을 진행하는데 쓰이 는 연산자이다. 론리연산자에는 론리 적 ( And ), 론리 합 ( Or ), 론 
리 부정 ( Not ) 이 있 다. 
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론리연산자와 괄호를 리용하여 련결하여놓은 식을 론리 식이 라고 한다. 

1) 론리적 ( And ) 

두 연산수가 동시 에 참 ( true ) 일 때 에만 참을 주는 연산이다. 즉 두 연산수가운데 
서 하나라도 거 짓 ( false ) 이면 거 짓을 준다. 

콤퓨터 에서는 참을 1로，거 짓을 0으로 표시한다. 


A 

B 

A and B 

false 

false 

false 

false 

true 

false 

true 

false 

false 

true 

true 

true 


2) 론리합 ( Or ) 

두 연산수가운데 서 어 느 하나라도 참 ( true ) 이 면 참 ( true ) 을 주는 연산이다. 두 
연산수가 둘 다 거짓 ( false ) 인 경우에만 거짓을 준다. 


A 

B 

A or B 

false 

false 

false 

false 

true 

true 

true 

false 

true 

true 

true 

true 


3) 론리부정 ( Not ) 

연산수가 참 ( true ) 이 면 거 짓 ( false ) 을 주고 거 짓 ( false ) 이 면 참 ( true ) 을 주는 연 
산이 다. 


A 

Not A 

false 

true 

true 

false 


C 언어에서는 이 론리연산자들을 어떻게 표시하는가? 
여 기서 는 다음과 같은 연산자를 리용한다. 


연산자 

의미 

례 

&& 

론리적 



론리합 

a b 

! 

• 

론리 부정 

!a 
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론리적과 론리합은 두개의 연산수를 가지나 론리부정은 연산수를 하나밖에 가지지 
않 는다. 

론리 연산은 프로그람에 서 비 교식 들사이 의 결 합연산에 리 용한다. 
ai ： 다음과 같이 수축에서 빗선친 구역을 론리식으로 표시해보아라. 


① 





► X 


수학적 표시 : x > -3 a x < 5 
론리 식표시 : x 〉=_3&& x <=5 


② 




수학적표시: x < -3 vx > 5 
론리 식표시 : x <=_3|| x 〉=5 



^ _ ’P 찌 . x 

0 5 


수학적표시 : x >5 

론리 식표시 : x 〉=5 또는 ! x <5 


우의 식 의 결 과를 따져보자. 

x =0 이 라고 하면 첫번째 그림 에 서 빗선친 구역(첫째 론리식 ) 에 속하므로 참의 결 
과가 나와야 할것이다. 

0〉=_3 && 0<=5 = true 

차 차 


차 


續聲: 

Ms 


V 우 

다음 론리식의 결과는 무엇인가? 
x 〉=_3&& x <=5 | ! x <5&&( x <=_3 x 〉=5) 
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2 . 비트연산자 


우리는 이미 여러가지 진수체계들에 대하여 학습하였다. 

콤퓨터는 내부적으로 2진수(0，1)를 리용하는 기계이다. 콤퓨터에서 0과 1만을 
기록할수 있는 한자리 기록위 치를 비트 ( bit ) 라고 하였다. 

비 트연산은 두 연산수의 대 응하는 비 트들끼 리 진행 하는 연산이 다. 

비 트연산은 콤퓨터 의 장치내 부에 서 진행 되 는 연산들을 아는데 서 매 우 중요한 
연산이라고 말할수 있 다. 

비 트연산에는 비 트론리연산과 비 트밀 기연산이 있 다. 

비 트론리연산은 비 트들사이 에 진행 되 는 론리연산이다. 

비 트밀기연산은 비 트단위 로 오른쪽 또는 왼쪽밀기 를 진행하는 연산이다. 

1) 비트■리연산자 

비 트론리연산자에는 다음과 같은것 들이 있 다. 


연산자 

의미 

& 

비 트론리 적 


비트론리합 

，、 

비트배타적론리합 

，、✓ 

비트론리부정 


매 개 비 트론리연산의 기 능은 이 미 학습한 론리연산과 같은데 1을 참으로，0을 
거짓으로 생각하고 결과를 구하되 결과 역시 참을 1로 표시하고 거짓을 0으로 
표시하면 된다. 여기서 비트배타적론리합은 비트단위의 두 연산수의 값이 서로 다를 
때 에만 론리합의 연산결과를 주고 같을 때 에는 0의 결과를 주는 연산이다. 


A 

B 

A^B 

0 

0 

0 

0 

1 

1 

1 

0 

1 

1 

1 

0 


려 I 1： 34 10 &60 10 =0100010 2 &0111100 2 =0100000 2 =32 10 

0 1 0 0 0 1 0 
& 0 11110 0 


0 1 0 0 0 0 0 
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34 10 |60 10 =0100010 2 |0111100 2 =0111110 2 =62 10 

0 1 0 0 0 1 0 



34 10 ᄉ 60 10 =0100010 2 ᄉ0111100 2 =0011110 2 =30 10 

0 1 0 0 0 1 0 



〜 34 10 =~0100010 2 =1011101 2 =93 10 

〜 0100010 

1011101 

비트론리 연산자들이 들어 있는 식을 쓸 때 에는 복잡성 을 피 하기 위 하여 비트론리 식 
에 괄호를 쓰는것 이 좋다. 

비 트론리 연산자들은 옹근수형 에 대 하여 서 만 적 용할수 있 다. 

2) 비 s 밀기연산자 

비 트밀 기 연산자에 는 왼쪽밀 기 연산자(<<) 와 오른쪽밀 기 연산자(〉〉) 가 있 다. 

비 트밀 기연산자가 들어간 식 의 일 반형 식 : 


연산수 연산수 2 
연산수 1〉〉연산수 2 


여기서 첫 식은 연산수1을 연산수2의 회수만큼 왼쪽밀기하라는 식 이고 둘째 식은 
연산수1을 연산수2의 회 수만큼 오른쪽밀 기하라는 식 이 다. 

례 2: 4 10 « 2 = 00100 2 « 2 = 10000 2 =16丄 0 
16io 〉〉2 = IOOOO 2 » 2 = OOIOO 2 = 4 ᅮᄋ 



수를 오른쪽밀 기할 때 와 왼쪽밀 기할 때 의 결 과는 본래 의 수와 
어떤 관계를 가지는가? i 
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3. 조건명령문 


명령문은 조건에 따라 실행순위를 조종하는 명 
명 령 문에 는 두갈래 조건명 령 문과 여 러 갈래 조건 1 


J 두길'래조건명령문 

f ■갈래조건명령문은 조건에 따라서 두 갈래가운데서 어스 
일반형 식: 

형식1: if (식) <명령문1〉 

형 식2: if (식 ) <명 령 문1〉 
else 〈명 령 문2〉 

형식1: if (식) 

{ 

명 령 블로크1; 

} 

else 

{ 

명 령 블로크2; 

} 





기능: 

• 형식1: 식의 값을 계산하여 식의 값이 참 (0 이 아니면)이면 명령문1을 실행한다. 

• 형식2: 식의 값을 계산하여 식의 값이 참이면 명령문1을，거짓이면 명령문2를 
실 행 한다. 

• 형식3: 식의 값을 계산하여 식의 값이 참이면 명령블로크1을，거짓이면 명령 
블로크2를 실 행한다. 

우의 형식들에서 해당한 조건밑에 수행해야 할 명령문이 여러개 되는 경우 명령문 
들의 모임을 명령■로크라 고 하였다. 

명 령블로크는 { } 로 묶어 표시한다. 

if 문안에 또 if 문을， else 문안에 다시 if 문을 쓸수 있다. 이 런 경우 else 는 제 일 가 
까운 if 문과 대응한다. 

레 1: 수값을 입 력하면 짝수인가 홀수인가를 출력하는 프로그람을 작성하여 라. 

^include < stdio . h > 

^include < stdlib . h > 

int mainO 

{ 

int a ； 

scanf ( f '% d M , & a ) ； 

if ( a %2==0) printf( f 'even number \ n n ); 
else printf (’’odd number \ n f ') ； 

} 

ai 2 ： 수값을 입력하여 정수이면 +기호를 출력하는 프로그람을 작성하여 라. 

^include < stdio . h > 

^include < stdlib . h > 


int mainO 

{ 
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int a ； 

scanf ( f '% d M , & a ) ； 
if ( a >0) printf ( f '+\ n M ) ；} 



Ell 3: 두 수 a , b 가운데 서 큰 수를 출력하는 프로그람을 작성하여 라. 


^include < stdio . h > 

#include < stdlib . h > 

int mainO 

{ 

int a , b ； 

scanf ( f '% d % d M , & a , & b ) ； 

if ( a > b ) printf( f 'big number =% d \ n ’’， a ); 

else printf (’’big number =% d \ n n ， b ) ； 

} 

우리 가 이 미 절의 앞부분에서 설정한 과제 에서 성 적 mark 가 4. 5이 상인가 아닌가 
에 대 한 처 리는 조건명 령 문을 리 용하여 다음과 같이 쓸수 있다. 

if ( mark 〉=4. 5) 

printf ( n 최 우등 \ n "); 

else 

{ 

if ( mark 〉=3. 5) 
printf (" 우등 \ n n ); 
else 

printf (’’ 보통 \ n ’’) ； 

} 

2) 여려갈래조건명령문 

여 러갈래조건명 령 문은 식의 값에 따라 여 러 갈래가운데서 어 느 하나의 처 리를 진 
행하는 명 령 문이다. 

일반형식: 
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기능: 

식의 값을 판정하여 값1，값2，…，값 n 가운데서 식의 값과 일치한 값에 해 당 
한 처 리를 진행한다. 처 리를 진행한 후에는 switch 문에서 빠져 나온다. break 문을 
만나면 즉시 switch 문에서 빠져 나온다. 만일 식의 값과 일치한 값이 없으면 
default 로 지정한 처 리를 진행한다. 



switch 문에서 사용하는 식 이나 값은 반드시 옹근수나 문자형과 같이 순서 있 
는 자료여 야 한다. 

break 문이 없는 경우에는 선택된 처 리를 실행 한 후에 다시 다음 case 처 리 에 
들어 간다. 다시말하여 break 문은 처 리가 실행된 후에 그 switch 문에서 빠져 나오 
기 위하여 사용된 다. 

E1I 4： 두개 의 옹근수를 입 력 하고 연산기 호 (한개 의 기 호)를 입 력하면 두개 의 수값에 
대 한 해 당한 연산을 수행 하여 결 과를 줄력 하는 프로그람을 작성 하여 라. 
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^include < stdio . h > 
^include < stdlib . h > 
int mainO 




{ float a , b ； 
char c ； 

scanf f ', & a , & b ) ； 
scanf & c ) ； 

switch ( c ) 

{ 

case , + , ： 

printf ( f '% f \ n M , a + b ) ； 
case : 

printf ( f '% f \ n M , a _ b ) ； 
case : 

printf ( f '% f \ n M , a * b ) ； 
case V ， * 

printf ( f '% f \ n M , a / b ) ； 
default ： 

printf (’’ 좋습니다.’’); 

} 


} 

ai 5 ： 2010 년 l 월 l 일이 금요일이라는것을 알고 이달의 임의의 날자를 입력하면 
요일을 출력하는 프로그람을 작성하여라. 

^include < stdio . h > 

^include < stdlib . h > 


int mainO 

{ 

short day ； 
scanf ( f '% d M , & day ) ； 
switch (day mod 7) 

{ 

case 1: 

printf ( f 'f riday \ n f ') ； 
case 2： 

printf ( f ' saturday \ n f ') ； 
case 3： 

printf ( f ' sunday \ n M ) ； 
case 4： 

printf ( f ' monday \ n M ) ； 
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case 5： 

printf (" tuesday \ n f ') ； 
case 6 

printf ( f ' wednesday \ n M ) ； 
case 0： 

printf (" thursday \ n f ') ； 


3) 무조건이행명령문 

프로그람집행과정에는 코드에 씌여진 순서대로가 아니라 필요에 따라 실행순위를 
변화시켜 야 할 때가 있다. 이렇게 순위를 변경시켜 어떤 명 령문에로 뛰여 념게 하는 
명 령 문이 바로 무조건이행 명 령 문이다. 

일반형식: 

goto 표식 ; 


기 능: 

표식 이 붙은 명 령 문에 로 이 행 한다. 

이 때 표식 에 는 수값을 쓸수 없 다. 변수이 름만들기규칙 에 서 와 같이 문자로 
시작하여 문자，수자들의 결합으로 지어야 한다. 

려 I 6: S = l + 2 + ."+100 을 계산하여라. 

^include < stdio . h > 
void main ( void ) 

{ 

int i = l ， s =0; 
lp : 
s += i ; 
i ++； 

if ( i <=100) goto lp ； 
printf (“ sum =% d \ n ”， s ) ； 

} 

C 프로그람에서 goto 문을 사용하면 프로그람의 구조가 복잡하게 되며 여러가지 
오유의 발생원인으로 되므로 goto 문의 사용은 될수록 금지하고있다. 

우리가 이 절에서 학습한 내용을 종합하여 이미 절의 앞부분에서 설정하였던 
과제의 코드를 쓰면 다음과 같다. 

< 코드〉 

^include < stdio . h > 

^include < stdlib . h > 
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int mainO 
{float mark ； 
scanf & mark ) ； 

if ( mark 〉=4. 5) 
printf (” 최 우등 \ n ’’); 
else 
{ 

if ( mark 〉=3. 5) 
printf (” 우등 \ n n ); 
else 

printf (’’ 보통 \ n ”) ； 



이 미 알고리 듬에 서 본바와 같이 성 적 mark 가 4. 5이 상인가를 판정하여 크면 
《 최 우등》이 라고 줄력 하며 아니 면 다시 3. 5이 상인가 아닌 가에 대 한 판정 을 진행 한다. 

3. 5보다 크면 《 우등》이 라고 줄력 하며 아니 면 《 보통》이 라고 줄력 한다. 

련습문제 

1. 다음 연산의 연산순위를 밝히고 연산결과를 구하여라. 

A = true , B = false , C=true 

1) A && B | |C 2) A | | B&&C 3)! A && C | | B&&!C 4) A || BUA||C 

2 . 다음 비트연산의 결과를 구하여라. 

1) 30&45 2) 25|12 3) 21^30 4) 〜21&3이40 

3. 다음 식의 결과를 구하여 라. 
x =-3, y = 6 일 때 

1) x <0&& y>l 2) x >0 | | y <7 3) ! ( x <0)&& y <-5 

4) x <01 | y >0 5) x <0&& x >-5 6) y >0&& y <10 

4. 세 수 a, b, c 가운데 서 제 일 큰 수를 출력하는 프로그람을 작성하여 라. 

5. 3각형 의 세 변 a , b , c 가 주어 졌 을 때 3각형 을 이 룰수 있는가를 판정 하고 이 룰수 
있으면 면적 을 구하여 출력하는 프로그람을 작성하여 라. 

6. 2차방정 식 의 풀이 를 구하는 프로그람을 작성하여 라. 

7. 점 M ( x , y ) 가 주어졌다. 이 점이 중심이 (0， 0) 이고 반경이 요인 원안에 놓이는가 
를 판정하여 출력하는 프로그람을 작성하여 라. 
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8 . 수값이 10개 주어 진다. 매 수값에 대 하여 정 수인가，부수인가，령인가를 판정하여 
출력하는 프로그람을 작성하여 라. 

9. 10개 의 수가 주어 진다. 매 수가 짝수인가，홀수인가를 판정하여 출력하는 프로그람 
을 작성하여 라. 

10. 세 점 A , B , C 가 주어졌다. 이 세 점 이 한 직 선에 놓이 는가를 판정하는 프로그람 
을 작성하여 라. 

11. 노의 값을 구하는 프로그람을 작성하여 라. 

广 x , i =0 

y = i sinx , i=l 
^ cosx , i =2 

12. y 의 값을 구하는 프로그람을 작성하여 라. 

r x 2 ， i=l 

x , i =2, 3, 6, 7, 8 

y = < 

sinx , i =9, 10, 11 
( tanx ) 2 +1, i>ll 

13. if 명령문과 switch 문의 공통점과 차이점을 말하여 라. 

14. 세 수 a, b, c 를 크기순서로 배 렬하여 라. 

15. a 값을 입 력하여 왼쪽으로 lbit 씩 밀기할 때 마다 나오는 결과들을 출력하는 프로그 
람을 작성하여 라. (5 번만 밀 기한다. ) 

16. 2010년 1월 1일 이 금요일 이라는것을 알고 2월의 임의의 날자를 입 력하면 요일을 
출력하는 프로그람을 작성하여 라. 

17. a 와 b 가 임의의 옹근수일 때 a 2 + b 2 의 값이 100보다 크면 100의 자리수，100보 
다 작으면 10의 자리 수를 출력하는 프로그람을 작성하여 라. 

18. 두 원의 중심점의 자리표와 반경이 각각 주어졌을 때 두 원이 사귀였는가를 판정 
하는 프로그람을 작성하여 라. 

19. 수 표가 주어졌을 때 20, 40，60가운데서 가장 가까운 수값을 출력하는 프로그람 
을 작성하여 라. 

20. 기 호를 입 력한다. 기 호가 A 인것 과 아닌것 의 개 수를 출력하는 프로그람을 작성하 
여라. 
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봄# 터상져 

《해커〉〉란 말의 진짜 의미 

콤퓨터 범죄 가 성 행 하는 속에서 어 느덧 사람들은《해커 ( hacker ) 》라는 말을 
《콤퓨터망에서 부정적 인 일을 하는 사람을 통털어 이르는 말》처 럼 리해 하고있 
다. 그러나 이 말의 원래의 의미는《손도끼 하나로 집을 짓는 사람》혹은《곡 
괭이로 땅을 파는 사람》이라는 뜻으로서 원래는 콤퓨터를 깊이 파고들어 많은 
지식을 소유하고있으며 탐구적이고 창조적인 재능에 넘친 프로그람개발자를 존 
경하여 부르는 말이였다. 해커들이 콤퓨터망에서 다른 사람들의 체계에 침투하 
여 들어가는 경우에도 나쁜 의도를 가져서 라기보다 순수한 호기심 이 나 탐구심으 
로부터 출발한 경 우가 많았다. 해커 란 말이 콤퓨터분야에서 쓰이 기 시 작한것 은 
죠세프 와이젠바움이라는 사람이《콤퓨터의 힘과 인간의 리성》이라는 책에서 탐 
구적인 프로그람개 발자들을 이 말에 비 유하여 표현한 때 부터 생 겨 났다. 


제6절. 10명 학생의 평균성적계산 


이 절에서 는 10명 학생 의 평 균성 적 을 계산하는 프로그람을 작성하는 과정 을 
통하여 순환명령문에 대하여 학습하기로 한다. 

10명 학생의 평균성적을 계산하는 프로그람을 작성하자. 이 문제를 물려면 10 
명 학생의 성적 을 입 력하여 더한 다음 10으로 나누어 평 균값을 계산하여 야 한다. 
알고리듬은 다음과 같다. 


<알고리 듬〉 



i -^1,10 


성 적 mark 읽 기 

s = s+mark 

s = s /10 

S 출력 


알고리 듬에 서 보는바와 같이 이 문제 는 i 값을 1부터 10까지 1씩 증가시키 면서 
매번 증가된 i 번호에 해당한 학생성적 mark 를 입력하고 그것을 합을 나타내는 변 
수 s 에 더하여 야 하며 성 적합계산이 끝나면 전체 성 적의 합을 10으로 나누어 평 균 
값을 계산하여 야 한다. 
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이렇게 주기적인 반복과정이 들어있는 알고리듬은 순환명령문을 통하여 실현 
할수 있다. 


1. 순환명령문 for 

우리는 이미 앞절에서 조건명령문과 무조건이행명령문에 대하여 학습하였다 . 

아래의 프로그람을 보기로 하자. 

mainO 
{ int i ； 

1： i = i + l ; 
s = s + i ; 

if ( i <10) goto 1; 

} 

이 프로그람에 서 3，4， 5 행 은 s = s + i 를 구하기 위한 명 령 문들이 다. 

이 과정 을 다시 보면 i = i + l 은 1，2，3,…와 같이 1씩 증가되 는 값들을 취해 주는 
명령문이며 if ( i <10) goto 1은 호의 끝값이 10이 되였는가 판단하며 아직 되지 않은 경 
우에는 i 를 증가시키는 위 치로 다시 순환시켜주기 위한 명 령문이다. 즉 이 프로그람에 
서 는 s = s + i 를 위해 i 를 1부터 1씩 증가， i <10 인가 판단，1행 에 로 이 행하는 과정 이 필요 
하다. 이 세 명령의 기능을 대신하여 간단히 하나로 쓸수 있는 명령이 바로 for 명령 
문이 다. 

for 명령문의 형식은 다음과 같다. 

일반형 식: 


for ([식 1]; [식 2]; [식 3]) 

{ 

명령 블로크; 

} 


기능: 

① 식1평가 

② 식2평가 

③ 식2의 값이 참이면 명령블로크를 실행하고 ④에로 이행，거짓이면 for 다음 
명 령 문에 로 이 행하여 순환을 끝낸 다. 

④ 식3을 평 가하고 ②에 로 이 행 
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Ell 1： s = l +2+3+ … +10 을 계 산하는 프로그람을 작성하여 라. 

^include < stdio . h > 
void main ( void ) 

{ int i , s =0; 

for ( i = l ; i <=10; i ++) 

s += i ; 

printf (“ sum =% d \ n ”， s ) ； 

} 

이 프로그람에서 식 1은 i = l ， 식 2는 i <=10， 식 3은 i ++ 이 다. 그러므로 i = l 을 수행 
하여 i 변수에 1을 넣 고 i <=10 인가 판정하여 참이 면 s+=i 명 령 문을 수행한 다음 i ++ 을 
수행하여 i 를 하나 증가시키 고 다시 for 명 령 의 i <=10 판정 에 로 넘어 간다. 만일 i <=10 
이 거짓 이면 즉 호가 10을 넘 었으면 for 순환의 다음에로 넘어가 printf 명 령문을 실행함 
으로써 s 를 출력한다. 

for 명 령 문에 서 주의할 점 은 다음과 같다. 

• 식1은 순환부에서 한번만 실행된다. 그러므로 순환에서 변수에 대한 초기화에 
리용되 며 생 략할수도 있 다. 

식 1에 여러 명령문을 쓸수도 있는데 이때에는 명령문들을 반점으로 구별하여 쓴다. 

우의 례에서 식 1자리 에 s = o 도 쓸수 있는데 그렇게 하려면 다음과 같이 쓸수 
있다. 

for ( s =0, i=l ; i <=10 ; i ++) 


s += i ; 
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• 식 2는 순환을 위한 조건 이 며 생 략되 면 무한순환이 된 다. 그러 므로 순환부에 는 
무한순환이 되지 않도륵 조건식이나 break 문을 리용하여 순환에서 빠질수 있는 명령 
문이 있어야 한다. 

• 식 3은 순환을 진행할 때마다 실행되는 부분으로서 순환변수를 걸음값만큼씩 
변 화시키 는데 리 용된 다. 

생략하면 이 부분이 명령블로크안에 있을수도 있다. 

3개의 항목이 다 생 략될수도 있다. 

for ( ； ；) 

명 령 문; 

• 명령문이 생략된 경우는 수행되는 명령문은 없지만 식 1，식 2，식 3에 대한 판 
단을 계속하면서 순환은 계속된다. 이것을 빈 순환이라고 한다. 

빈순환은 시 간지연에 리 용된다. 

for ( i = l ； i <50000； i ++)； 

• for 순환에서 break 문이 나 continue 문을 리 용하면 무한순환을 피 할수 있다. 

break ： 순환중지 
continue : 순환계 속 

continue 문이 실행 되 면 이 명 령부터 순환부의 마지 막명 령문까지를 무시 하고 다음 
순환에 로 넘어 간다. 

break 문이 실행되면 이 명령문 다음부터 순환부의 마지막명령문까지는 무시되고 
순환이 중지된다. 

례 2: s =2+4+6+ …+500의 합이 1 000을 넘을 때 순환을 중지 하고 합을 출력 하는 
프로그람을 작성하여 라. 

^include < stdio . h > 

#include < stdlib . h > 


int mainO 

{ 

int i , s =0; 
for ( i =0; i <=500; i +=2) 

{ 

s += i ; 

if ( s >1000) break ； 

} 

printf ( f ' s =% d \ n M , s ) ； 
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ai 3： 각 표가 -360 ᄋ 一 +360ᄋ 까지 변 할 때 매 각의 sin , cos , tan 값을 출력하는 
프로그람을 작성하여 라. 

이 문제에서는 각 표가 ±90ᄋ ， ±270ᄋ 일 때에는 tan 값이 정의되지 않으므로 이 
값일 때는 피해야 하므로 continue 문을 쓰는것이 적합하다. 

^include < stdio . h > 
itinclude < stdlib . h > 

#include < math . h > 

int mainO 

{ 

int i ； 

float s , c , t , x ； 
for ( i =0; i <=360; i ++) 

{ 

x = i *3.14/180; 
s = sin ( x ) ； 
c = cos ( x )； 
if ( i ==90 | | i ==270) 

{ printf ( f '% d ： %f %f no \ n f ', i , s , c ) ； 
continue ； 

} 

t = tan ( x ) ； 

printf ( f '% d ： %f %f % f \ n f ', i , s , c , t ) ； 

} 

} 

ai 4: 2010 년 1 월 1 일 이 금요일 이라는것을 알고 임의의 월，일을 입 력하면 요일을 
출력하는 프로그람을 작성하여 라. 

^include < stdio . h > 

^include < stdlib . h > 

int mainO 


int i ， m ， n ， s =0， d ; 
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scanf ( f '%d%d M , &m, &n) ； 

for(i=l ;i<=m_l ;i++) 
switch (i) 

{ 

case 1 : 
case 3： 
case 5： 
case 7 : 
case 8： 
case 10： 
case 12： 
s=s+31； 
break； 
case 2： 
s=s+28; 
break； 
case 4： 
case 6： 
case 9： 
case 11: 
s=s+30; 
break； 

} 

s=s+n; 
d=s%7 ； 
switch (d) 

{ 

case 0： 

printf(” 목요일’’); 
break； 
case 1: 

printf(” 금요일’’); 
break； 
case 2： 

printf (’’ 토요일 ’’) ； 
break； 
case 3： 

printf (’’일 요일 ’’) ； 
break； 
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case 4 ： 

printf (’’ 월요일 ’’) ； 
break ； 
case 5 ： 

printf ("화요일 ’’) ； 
break ； 
case 6 ： 

printf (’’ 수요일 ’’); 
break ； 

} 

} 

순환명 령 문들은 어떤 명 령 문들을 하나로 묶어 이것 을 반복하여 집 행하도록 하는 
명 령 문이 다 . 

앞에서 설정한 문제 에 대 한 코드를 보자 . 

^include <stdio. h> 

^include <stdlib. h> 

int mainO 

{ 

float mark, s=0 ； 
int i ； 

for(i=l ； i<=10 ； i++) 

{ 

scanf &mark) ； 
s=s+mark; 

}； 

s=s/10 ； 

printf ( f '%f\n M , s) ； 



이미 앞에서 설정된 문제에서 1 부터 10 까지 1 씩 증가한다는 내용은 for 문의 시작 
부분으로 대신하였고 이 조건하에서 반복하여야 할 입력과 성적합계산은 순환부안에 
넣 었다 . 다음 순환부가 끝나면 성적 을 10 으로 나누어 출력하였다 . 
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2. 순환명령문 while 


while 은《 •••하는 동안》이 라는 뜻으로서 조건이 만족되는 동안 처 리를 진행 하게 
하는데 리 용된 다. 앞에 서 설 정 하였 던 문제 를 while 문으로 작성하면 다음과 같다. 

^include < stdio . h > 
mainO 
{ float s =0; 
int i = l ; 
while ( i <=10) 

{ 

scanf (“ % f ’，& x ) ； 

s += x ; 

i ++； 

}； 

printf (“% f \ n ”， s /10) ； 

} 

여기서 보는것처 럼 i 는 인원수를 세는 변수로서 성적 입 력과 합구하기는 변수 소가 
10이 아닌 동안 계속 반복해야 할 명령문들이다. 즉 while 옆에는 명령문을 반복해야 
할 조건식을 넣는다. 



기능: 

식의 값이 참(유 0) 인 동안 명령문 또는 명령블로크를 반복하여 실행하며 거짓이 
면 순환부 다음 명 령 문에 로 이 행한다. 

이 순환명 령 문에 서 주의할 점 은 다음과 같다. 

• 이 명 령 문들가운데 는 식 의 값을 변화시키 는 명 령 문이 득 있 어 야 한다. 

이런 명령문이 없으면 무한순환에 빠질수 있다. 
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i =0; 

while ( i <=10) 
printf (“ ** ”) ； 

이 례에서 는 i =0 을 실행한 후 **를 출력하는데 언제 가도 호가 10을 넘 을수 없으므 
로 무한순환에 들어가게 된 다. 즉 


i =0; 

while ( i <=10) 

{ 

i ++； 

printf ； 

} 

호가 i 씩 증가하므로 i <= io 은 언젠가는 거짓으로 되여버린다. 

• 식의 값이 처음부터 거짓이면 순환부는 한번도 실행되지 않는다. 

E1I 2 ： s=l+2+3+."+10 을 구하는 프로그람을 작성하여 라. 

mainO 

{ 

int i = l ， s =0; 
while ( i <=10) 

{ 

s += i ; 

i ++； 

}； 

printf (“ % d \ n ’’， s ) ； 

} 

근 II 3: s=l 2 +2 2 +3 2 + …의 합이 100 을 넘을때 마디번호와 그 합을 출력하는 프로그 
람을 작성하여 라. 

^include < stdio . h > 

^include < stdlib . h > 

int mainO 

{ 

int i = l ， s =0; 
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while ( s <=100) 
{ s += pow ( i ，2) ； 
i ++； 

} 

printf ( f '%d % d \ n f ', i , s ) ； 


3. dc 卜 whilen 


이 명 령 문도 while 문과 비 슷한 명 령 문이 다. 
다만 조건식 을 뒤 에서 판정하게 되 여있다. 

일반형식: 


참 


여기서 보는바와 같이 이 명령문은 우의 while 문과 반대로 조건식을 마지막에 판 
정 한다. 

기능: 

순환부를 먼저 실행하고 식의 값을 판정하여 이것이 참인 동안 순환부를 반복한다. 
식 의 값이 거 짓 으로 되 면 while 다음명 령 문에 로 이 행 하여 순환은 중지된다. 

이 명 령 문에 서 는 순환부를 먼저 실 행 하고 조건식 을 판정하므로 조건식 이 참이든 
거짓이든 순환부가 한번은 실행된다. 

려 I 1: n 9 ( n 은 1〜50사이 의 수)을 do 〜 while 명 령 문을 리 용하여 구하는 프로그람을 
작성 하여 라. 

^include < stdio . h > 

#include < stdlib . h > 


do 

{ 

명 령 블로크 ; 

} 

while (식 ) 



int main(int argc , char * argv []) 
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int n ， i = l ; 
float y=l ； 




scanf ( f '% d M , & n ) ； 
if ( l<=n && n <=50) 

{ 

do 

{ 

y *= n ; 

i ++； 

} 

while ( i <=9) 

} 

printf ( f '% f \ n M , y ) ； 

} 

Ell 2： a , b 의 최 대공통약수를 유클리 드련제법 으로 구하는 프로그람을 작성하여 라. 

^include < stdio . h > 

^include < stdlib . h > 

int main(int argc , char *argv []) 

{ 

int a , b , c ； 

scanf ( f '% d % d M , & a , & b ) ； 
do 
{ 

c=a % b ； 

b = c ; 

} 

whileCc ! =0) 
printfdd \ n n ， a ) ； 

} 

이 문제는 while 문으로 한다면 처음부터 c 는 0이므로 순환부가 한번도 실 
행되지 않는다. 따라서 이 문제에서는 while 문보다 do ~ while 문이 더 합리적 
이 라고 볼수 있 다. 
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4. 다중순환 


다중 순환이 란 순환부안에 또 다른 순환부를 가지 는 순환명 령 문이다. 
다중순환의 일반형래: 



우에서 순환고리란 순환이 시작되여서부터 순환이 끝나는 곳까지의 위치를 
말 한 다 . 

① S 태례: 

for ( i =0; i <=10; i ++) 

{ 

for ( j =0； j <= i ; j ++) 

{ 

for ( k =0; k <= j ; k ++) 
printf (1 d % d % d \ n ”， i , j , k ) ； 
printf (1 d 》 d \ n ”， i , j ) ； 

} 

printf (“ % d \ n ”， i ) ； 

} 


② 형태 례: 


for ( i =0; i <=10; i ++) 

{ 
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for ( j =0; j <=10; j ++) 
printf (1 d \ n ’’， j ) ； 
for ( k =0; k <=10; k ++) 
printf (1 d \ n ’’， k ) ； 
printf (“ % d \ n ’’， i ) ； 


③형태례: 


{ 

scanf (“% d ”，& a ) ； 
for ( i =0； i < a ； i ++) 
for ( j =0; j <= i + l ; j +=2) 
printf (1 d 》〔 Ud \ n ”， a , i , j ) ； 
} while ( a ! =0) 


다중 순환에서 순환 변수들의 변화 규칙 

다중순환에서 바깥순환변수가 한번 변할 때 안순환변수는 시작값부터 끝값까지 
차례로 변한다. 


이 규칙은 시계에서 초침이 60번 값이 변해야 분침이 한번，분침이 60번 변한 다 
음에야 시침이 한번 변하는것과 비슷하다. 

그러므로 시계의 시，분，초는 3중순환이며 다음과 같이 표시하면 시계의 시 간을 
모의할수 있 다. 

for ( h =0; h <= ll ; h ++) 
for ( m =0; m 〈=59; m ++) 
for ( s =0; s <=59; s ++) 
printf (% d % d % d \ n ”， h , m , s ) ； 

레 1: 구구표를 출력하는 프로그람을 작성하여 라. 


^ include 〈 stdio . h 〉 
^include < stdlib . h > 
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int mainO 


int i ， j ; 

for ( i = l ; i <=9; i ++) 

for ( j = l ; j <=9; j ++) 

printf ( f '%d * %d = M \ n ’’， i , j , i * j ); 

} 

ai 2 ： l 부터 50 까지의 자연수들에 대하여 매 수들이 씨수인가 합성수인가를 판단 
하여 출력하는 프로그람을 작성하여 라. 

^include < stdio . h > 

^include < stdlib . h > 

int main (int argc , char * argv []) 

{ 

int i ， j ; 

for ( i = l ; i <=50; i ++) 

{ 

for ( j =2; j ++) 

{ 

if ( i % j ==0) goto 1; 

} 

printf (”% d 는 씨 수이 다. ’’， i ) ； continue ； 

1 :printf (”% d 는 합성 수이 다. ”， i ); 

} 

} 

다중순환에 서 주의할 점 은 다음과 같다. 

• 다중순환에서 바깥순환은 안순환을 완전히 포함해야 하며 바깥순환고리와 안순 
환고리는 서로 사귀지 말아야 한다. 

• 바깥순환변수와 안순환변수는 서로 같을수 없다. 

• 안순환에서 바깥순환에로는 나갈수 있지만 바깥순환에서 안순환에로는 들어갈 
수 없다. 
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1，2，3， 4 네 


리용하여 반복을 허 용하면서 세 자리수를 만들 


려면 몇중순환을 리용하여 야 하는가? 


J 


련습문제 


1. n ! 을 구하는 프로그람을 작성하여 라. 

2 . l / l *2+ l /2*3+".+ l / n *( n + l ) 을 구하는 프로그람을 작성하여 라. 

3. 1/1! _ 1/2! +1/3!— + l / n ! 을 구하는 프로그람을 작성하여라. 

4. 1+3+3 2 +•••의 합이 10 000을 넘 을 때의 마디번호를 출력하는 프로그람을 작성 
하 여 라 . 

5. 표의 n 제 곱을 표준함수를 리용하지 말고 구하는 프로그람을 작성하여 라. ( n 은 
옹근수) 

6. 각 표가 -360 ᄋ 부터 360ᄋ 까지 1° 간격 으로 변 할 때 삼각함수값들을 출력하는 프 
로그람을 작성하여 라. 

7. 표가 1부터 100까지 0.1 간격 으로 변할 때 로그，지 수함수값을 출력하는 프로그람을 
작성 하여 라. 

8. i + n + m +".+ m ." i ( i 의 개수 io 개)을 구하는 프로그람을 작성하여라. 

9. l +4 a +9 a 2+ •••에 서 n 이 주어질 때 n 번째 마디 까지 의 합을 구하는 프로그람을 작성하 
여라. 

10. l +3 b +5 b 2 + •"에 서 단이 주어질 때 n 번째 마디 까지 의 합을 구하는 프로그람을 
작성 하여 라. 

11. 첫째 마디 가 n 이 고 공통비 가 2인 같은비 수렬에 서 처 음 몇개 마디 의 합을 잡으면 
그것 이 1 000보다 크게 되겠는가를 줄력 하는 프로그람을 작성 하여 라. 

12. 0，1，1，2，3，5，8, •••의 첫 20번째 마디 까지 의 합과 20번째 마디 를 출력 하는 프 
로그람을 작성하여 라. 

13. 100개 의 실 험측정자료가 있다. 정 수이면서 홀수번째 인 자료들의 합과 개 수를 출력 
하여 라. 

14. 1 111 — 5 000까지 의 수들가운데 서 10의 자리수자와 1의 자리수자가 같은 수들 
을 모두 출력 하고 그 개 수를 출력하여 라. 

15. a 부터 b 까지 의 자연수들의 합을 출력하는 프로그람을 작성하여 라. 

16. 자연수가 주어졌 다. 이 수가 씨 수인가 합성 수인가를 판정하여 출력하는 프로그람 
을 작성하여 라. 
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17. 자연수가 주어 졌 다. 이 수가 합성 수 이 면 이 수를 씨 인수분해 하는 프로그람을 작 
성 하여 라. 

18. 두 수의 최 대공통약수와 최 소공통배 수를 출력하는 프로그람을 작성하여 라. 

19. 두 수 a, b 가 주어졌다. 이 두 수를 최대공통약수，최소공통배수로 하는 두 수를 
구하는 프로그람을 작성하여 라. 

20. 10부터 100까지 자연수가운데 수자 3이 모두 몇개 있는가를 구하는 프로그람을 
작성 하여 라. 

21. (2)，(4，6)，(8，10， 12), •••인 수묶음이 주어졌다. 20번째 묶음까지 매 묶음의 
합과 그 묶음을 출력하는 프로그람을 작성하여 라. 

22. (1), (2, 3, 4), (5, 6, 7, 8, 9), (10, 11, 12, 13, 14, 15, 16), •"인 수 
묶음이 있다. 20번째 묶음까지의 매 묶음과 그의 합을 출력하는 프로그람을 
작성 하여 라. 

23. s = l + x / l !+ x 2 /2!+ x 3 /3!+ •"을 소수점 아래 6자리까지의 정확도로 구하는 프로그람 
을 작성하여 라. 

24. sinx 의 값을 표준함수를 리용하지 말고 전개공식 을 리용하여 소수점아래 5자리까 
지 정 확도로 구하는 프로그람을 작성 하여 라. 

25. ab * ba =403 이 되 는 a 와 b 를 구하는 프로그람을 작성하여 라. 

26. s = l +21+321+1321+21321+321321+---+ pi 321*--321^ 구하는 프로그람을 작성 하 

여라. V Y ； 

15 자리 


27. s = l +12+123+1231+12312+123123+."+123123."123 을 구하는 프로그람을 작성 하 


여라. 



Y 



15 자리 


28. 11로 완제되 면서 하나의 자리수자는 7인 6자리수가 있다. 이 수의 하나의 자리수 
자，열의 자리수자，백의 자리수자를 지워버리면 597이 된다. 이런 수는 몇개이 
며 어떤 수인가? 


29. 


s = l -12+123-1231+12312-123123+.. 

여라. 


—123123 …123을 구하는 프로그람을 작성하 



30 자리 


30. 옹근수 n 이 주어졌 다. 요의 약수들의 합과 그 개 수를 출력하는 프로그람을 작성하 
여라. 
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통# 터상져 

전자우편이란 어떤것인가? 

현재 세계적으로 콤퓨터 망을 통한 우편거래방식 즉 전자우편 (E - mail ) 방식 
이 널 리 리용되 고있 다. 어 떤 사람들은 전자우편과 아주 친숙해 져 친절 하게 《 누 
이동생》이 라고 부르기 까지 하고있 다. 

그러면 전자우편이란 무엇이며 여기에도 우편국과 우편함이 있는가? 

통속적 으로 일 반우편과 달리 콤퓨터망을 통하여 주고받는 우편을 전자우편 
이라고 하며 이것을 실현할수 있는 체계를 전자우편체계라고 한다. 물론 전자우 
편체계에도 우편국과 우편함이 있다. 

일 반적 으로 우리 들은 콤퓨터 망봉사제 공자에 망가입 신청 을 하는데 이 때 콤퓨 
터망봉사제공자는 필요한 수속처리와 함께 동시에 가입자에게 하나의 전자우편 
주소를 제공하게 된다. 그러면 이 콤퓨터망봉사제공자의 전자우편봉사기가 바로 
《전자우편국》으로 되는데 이 우편국에서는 동시에 자기의 기억기안의 일정한 
구역 을 내 여 하나의 〈〈전자우편함》을 설정해놓는다. 이 렇게 전자우편국과 전자 
우편함들은 콤퓨터망봉사제공자의 봉사기 에 존재하게 되며 이것 에 의하여 관리 
된다. 

전자우편의 전송과정은 일반우편방식에 서와 류사하다. 

김동무가 안동무에게 전자우편을 보낼 때 전자우편은 먼저 자기의 전자우편 
봉사기 에 보내 여지며 곧 자기의 전자우편함에 넣어 진다. 다음 전자우편봉사기 는 
김 동무의 전자우편을 콤퓨터망을 통하여 안동무가 등록되 여있는 전자우편봉사기 
에 전송하며 이것은 다시 안동무의 전자우편함에 넣어 진다. 이 렇게 되면 안동무 
가 전자우편쏘프트웨어 를 리용하여 자기 의 전자우편함을 조사해볼 때 김 동무가 
보낸 전자우편 을 발견하고 열 어보게 된 다. 

전자우편체계에서는 일반우편에서 와는 달리 우편통과 우편함이 따로 설치되 
여 있지 않다. 전자우편국은 곧〈〈우편구역》안의 매 사람들에게 배정된 우편함으 
로서 매 사람들은 보내는 우편을 자기의 우편함에 넣으면 된다. 이렇게 전자우 
편함이 전자우편국안에 직접 설치되 여있기때문에 편지를 보내고 받는것 이 모두 
아주 빠르게，아주 헐 하게，편 리 하게 진행 되 게 된다. 




87 



















콤퓨터(제1중학교 제5학년용) 

집 m 

정금진，리은경， 

심 

사 

심의위원회 


김창혁，리영걸 




편 집 

길명희 




장 정 

김 순영 

교 

정 

오혜 란 

낸 끗 

교육도서 출판사 

인쇄소 

평 양고등교육도서 인쇄 공장 

인 쇄 

주체 99(2010) 년 

11월 20일 발 

행 

주체 99(2010) 년 11월 30일 


교- 10 — 657 






